Python猎鹰转换是只读的

问题描述

当我试图从我的 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)

并且数据库调用在来自 psycopg2 包的这一行上失败。

self.execute_query(q,dict_cursor=dict_cursor,readonly=readonly,autocommit=autocommit,conn=False)

解决方法

在我的情况下,发生问题是因为我使用的一个 mviews 是两个不同 mviews 的组合(联合所有),并且出于某种原因,psql 抛出一个错误,指出事务是只读的。解决此问题的错误消息非常不清楚。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...