python – SQLAlchemy – 将文本查询与过滤器结合使用
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python – SQLAlchemy – 将文本查询与过滤器结合使用,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1310字,纯文字阅读大概需要2分钟。
内容图文
![python – SQLAlchemy – 将文本查询与过滤器结合使用](/upload/InfoBanner/zyjiaocheng/898/501349f6df4346f49e31ff4a3d6b9162.jpg)
我使用的是SA 0.6.6,Python 2.66和Postgres 8.3.
我有一些查询需要一些复杂的安全检查,可以使用WITH RECURSIVE查询来处理.我想要做的是将文本查询与查询对象结合起来,以便我可以根据需要应用过滤器.
我最初的想法是将我的文本查询创建为子查询,然后将其与用户的查询和过滤器相结合.不幸的是,这不起作用.
subquery = session.query(sharedFilterAlias). from_statement(sharedFilterQuery).subquery()
这会导致此错误:
AttributeError: 'Annotated_TextClause' object has no attribute 'alias'
反正将文本查询与SQLAlchemy的查询对象结合起来了吗?
解决方法:
经过一段时间没有回答I posted to the SA Google Group,Michael Bayer自己让我朝着正确的方向前进.
答案是将我的文本查询转换为SA文本子句.然后使用in_运算符.这是成品的一个例子:
sharedFilterQuery = '''WITH RECURSIVE
q AS
(
SELECT h.*
FROM "Selection"."FilterFolder" h
join "Selection"."Filter" f
on f."filterFolderId" = h.id
WHERE f.id = :filterId
UNION
SELECT hp.*
FROM q
JOIN "Selection"."FilterFolder" hp
ON hp.id = q."parentFolderId"
)
SELECT f.id
FROM "Selection"."Filter" f
where f.id = :filterId and
(f."createdByUserId" = 1 or
exists(select 1 from q where "isShared" = TRUE LIMIT 1))
'''
inClause = text(sharedFilterQuery,bindparams=[bindparam('filterId',filterId)])
f = session.query(Filter).filter(Filter.description == None).filter(Filter.id.in_(inClause)).first()
内容总结
以上是互联网集市为您收集整理的python – SQLAlchemy – 将文本查询与过滤器结合使用全部内容,希望文章能够帮你解决python – SQLAlchemy – 将文本查询与过滤器结合使用所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。