[英]Sqlalchemy Core, insert statement returning * (all columns)
I am using sqlalchemy core (query builder) to do an insert using a table definition.我正在使用 sqlalchemy 核心(查询生成器)使用表定义进行插入。 For example:
例如:
table.insert().values(a,b,c)
and I can make it return specific columns:我可以让它返回特定的列:
table.insert().values(a,b,c).returning(table.c.id, table.c.name)
but I am using postgres which has a RETURNING *
syntax, which returns all the columns in the row.但我使用的是具有
RETURNING *
语法的 postgres,它返回行中的所有列。 Is there a way to do that with sqlalchemy core?有没有办法用 sqlalchemy 核心做到这一点?
query = table.insert().values(a,b,c).returning(literal_column('*'))
And you can access it like你可以像这样访问它
for col in execute(query, stmt):
print(col)
要获取所有表列,还可以执行以下查询:
table.insert().values(a,b,c).returning(table)
或者,您可以扩展表列:
table.insert().returning(*table.c).values(a,b,c)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.