我正在尝试使用以下命令构建 SQLAlchemy 查询位置() http://www.postgresql.org/docs/9.1/static/functions-string.html功能。使用它生成以下形式的 SQL 的正确语法是什么POSITION('@' IN some_column)
?
I tried func.position('@', MyTable.my_column)
,但这会生成 SQLPOSITION('@', my_table.my_column)
,而不是使用IN
.
诀窍是使IN
对子字符串作为文字进行操作,如下所示:
import sqlalchemy as sa
q = sa.select(
sa.func.position(sa.literal('@').op('IN')(tbl.c.my_column)
)
编译时会生成此 SQL
SELECT position('@' IN tbl.my_column) AS position_1 \nFROM tbl
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)