问题描述
当我试图从我的 python 应用程序中读取我的 redshift 数据库中的数据时,我遇到了一个奇怪的错误 -psycopg2.errors.ReadOnlysqlTransaction: transaction is read-only
。我不是要修改数据库,所以我不确定为什么会发生这种情况。我正在使用 postgresql 插件 (psycopg2) 版本 2.8.4。和 python 3.5 版 - 我有很多其他查询,我正在以相同的方法运行并且它们没有问题,所以我有点困惑可能导致这种情况的原因。
这是我正在运行的查询
SELECT
stat_date,age,name,SUM(spent) as spent,FROM (
SELECT stat_date,spent
FROM mview_a
WHERE id in ('id1','id2')
UNION ALL
SELECT stat_date,spent
FROM mview_b
WHERE id in ('id1',spent
FROM mview_c
WHERE id in ('id1',spent
FROM view_d (combination of multiple mviews)
WHERE id in ('id1',spent
FROM mview_e
WHERE id in ('id1','id2')
)
GROUP BY 1;
这就是我将查询与参数一起传递的方式
dw = self.get_conn(conn)
results = dw.fetch_all_query(query,params=params,**kwargs)
self.execute_query(q,dict_cursor=dict_cursor,readonly=readonly,autocommit=autocommit,conn=False)
解决方法
在我的情况下,发生问题是因为我使用的一个 mviews 是两个不同 mviews 的组合(联合所有),并且出于某种原因,psql 抛出一个错误,指出事务是只读的。解决此问题的错误消息非常不清楚。