作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用原始 sqlalchemy text()
查询将值插入 Postgres11 数据库。当我通过 psql-client 运行以下 SQL 查询时,它可以正常工作:
WITH a AS (
INSERT INTO person (id)
VALUES ('a')
RETURNING id
)
INSERT INTO person_info (person_id)
SELECT id
FROM a;
所有行均已正确插入:
# select id from person;
id
----
a
(1 row)
但是,如果我在 sqlalchemy 中创建一个引擎并使用相同的查询对其调用执行,它会成功运行,但不会插入任何行:
>>> engine.execute("WITH a AS (INSERT INTO person (id) VALUES ('b') RETURNING id) INSERT INTO person_info (person_id) SELECT id from a")
<sqlalchemy.engine.result.ResultProxy object at 0x7f25e6c2a090>
但没有插入新行:
# select id from person;
id
----
a
(1 row)
通过 psql-client 运行查询与通过 sqlalchemy 执行查询有何不同?
最佳答案
我的问题得到了answered on github .
解决方案是将执行包装在事务上下文中:
with engine.begin() as conn:
conn.execute("whatever")
关于python - 使用 python sqlalchemy 通过WITH语句执行原始查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59699937/
我是一名优秀的程序员,十分优秀!