DeepSeek总结的Turso的CTE支持情况

原文地址:https://github.com/tursodatabase/turso/issues/4637

一、总体情况

Turso 仅支持 基本 CTE(仅限于 SELECT 语句),且存在多项关键限制。相比 SQLite,其 CTE 支持尚不完整。


二、支持与不支持的功能对比

已支持的功能(基本 SELECT CTE):
  • 单个 CTE、多个 CTE、CTE 间相互引用
  • 包含 ORDER BYLIMITGROUP BYDISTINCT
  • 包含 CASECOALESCEEXISTSINLEFT JOIN 等复杂表达式
  • 包含聚合函数、数学运算、字符串函数、VALUES 子句等
  • 可在子查询或嵌套查询中使用
不支持或存在问题的功能
  1. CTE 无法被多次引用(关键缺陷)

    • 同一 CTE 不能在查询中引用超过一次(如自连接、多次出现在子查询中)。
  2. CTE 内不支持复合查询(BUG)

    • UNIONINTERSECTEXCEPTUNION ALL 在 CTE 内部会被错误拒绝。
  3. CTE 不能与 DML 语句结合使用

    • 不支持 WITH ... INSERTWITH ... UPDATEWITH ... DELETE
  4. 不支持显式列名定义

    • WITH t(a, b) AS (...) 语法不被支持。
  5. 不支持递归 CTE

    • WITH RECURSIVE 语法不被支持。
  6. CTE 不能遮盖同名表

    • SQLite 允许 CTE 遮盖同名表,但 Turso 会直接拒绝。
  7. 不支持 MATERIALIZED 提示

    • NOT MATERIALIZED 可被接受(但被忽略),MATERIALIZED 则被拒绝。

三、关键问题示例

sql 复制代码
-- 1. CTE 无法多次引用(失败)
WITH t AS (SELECT 1 AS x) SELECT * FROM t, t AS t2;
-- 错误:no such table: t

-- 2. CTE 内不能使用 UNION(失败)
WITH t AS (SELECT 1 UNION SELECT 2) SELECT * FROM t;
-- 错误:Only SELECT queries are currently supported in CTEs

-- 3. 不能与 INSERT 等同使用(失败)
WITH t AS (SELECT 1 AS x) INSERT INTO table SELECT * FROM t;
-- 错误:WITH clause is not supported

四、修复优先级建议

  1. 关键:CTE 多次引用问题(影响多数常用场景)。
  2. :CTE 内支持复合查询(UNION 等)。
  3. :支持 CTE 与 DML 结合、显式列名定义。
  4. :CTE 遮盖表名、MATERIALIZED 提示。
  5. 未来:递归 CTE(明确标记为尚未支持)。

五、其他说明

  • 报告指出 SQLite 本身也不支持 WITH ... INSERT ... RETURNING 语法,因此 Turso 在此方面无需立即为兼容性实现该功能。
  • 存在一个关于递归 CTE 的未合并 PR,但目前非优先事项。

总结

Turso 的 CTE 支持目前处于 基础可用但限制明显 的阶段,适用于简单的查询分解和重用,但无法应对需要多次引用同一 CTE、使用复合查询或与数据修改操作结合的复杂场景。开发团队已识别关键问题并设置了修复优先级。

相关推荐
重生之绝世牛码2 小时前
Linux软件安装 —— ClickHouse集群安装(集成Zookeeper)+ chproxy负载均衡
大数据·linux·数据库·clickhouse·软件安装·clickhouse集群安装·clickhouse负载均衡
l1t2 小时前
修改德哥的PostgreSQL求解数独SQL在cedardb上运行
数据库·sql·postgresql·cedardb
想做一只开心的菜鸡2 小时前
DARTS#01 | Tournament Sort算法 | MySQL深度翻页优化技巧 | 论文ByteSlice Review
数据库·mysql·算法
一只自律的鸡2 小时前
【MySQL】第八章 数据类型
数据库·mysql
喵手2 小时前
Python爬虫零基础入门【第九章:实战项目教学·第5节】SQLite 入库实战:唯一键 + Upsert(幂等写入)!
爬虫·python·sqlite·爬虫实战·python爬虫工程化实战·零基础python爬虫教学·sqlite入库实战
算法小菜鸟成长心得3 小时前
postgresql18 版本,使用navicate15版本出现不兼容问题
数据库
while(1){yan}13 小时前
Spring事务
java·数据库·spring boot·后端·java-ee·mybatis
盛世宏博北京13 小时前
高效环境管控:楼宇机房以太网温湿度精准监测系统方案
开发语言·数据库·php·以太网温湿度变送器
运维行者_13 小时前
2026 技术升级,OpManager 新增 AI 网络拓扑与带宽预测功能
运维·网络·数据库·人工智能·安全·web安全·自动化