gpt4 book ai didi

python - 使用 python sqlalchemy 通过WITH语句执行原始查询

转载 作者:行者123 更新时间:2023-12-01 00:09:55 24 4
gpt4 key购买 nike

我正在尝试使用原始 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com