[英]Malformed query generated by sqlalchemy when using a union with a CTE
我正在嘗試使用SQLAlchemy生成涉及CTE和聯合的查詢。 不幸的是,每當我應用聯合時,生成的SQL都不包含定義的CTE。
這是包含WITH的SQL,不帶UNION:
(Pdb) import sqlalchemy as sa
(Pdb) print str(sa.select([sa.select([sa.sql.null().label('a1')]).cte('bb')]))
WITH bb AS
(SELECT NULL AS a1)
SELECT bb.a1
FROM bb
現在,執行相同的查詢,但調用工會:
(Pdb) print str(sa.select([sa.select([sa.sql.null().label('a1')]).cte('bb')]).union_all(sa.select([sa.sql.null().label('b1')])))
SELECT bb.a1
FROM bb UNION ALL SELECT NULL AS b1
我希望帶有聯合調用的查詢仍包含WITH,但事實並非如此。
我確實相信這是一個錯誤。 我應用了以下補丁程序使UNION與CTE一起使用:
--- sqlalchemy.orig/sql/compiler.py 2012-05-20 17:39:41.000000000 +0000
+++ sqlalchemy/sql/compiler.py 2012-05-20 17:39:00.000000000 +0000
@@ -562,6 +562,15 @@
text += (cs._limit is not None or cs._offset is not None) and \
self.limit_clause(cs) or ""
+ if self.ctes and \
+ compound_index==1 and not entry:
+ cte_text = self.get_cte_preamble(self.ctes_recursive) + " "
+ cte_text += ", \n".join(
+ [txt for txt in self.ctes.values()]
+ )
+ cte_text += "\n "
+ text = cte_text + text
+
self.stack.pop(-1)
if asfrom and parens:
return "(" + text + ")"
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.