微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Python猎鹰转换是只读的

如何解决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 抛出一个错误,指出事务是只读的。解决此问题的错误消息非常不清楚。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?