Sqlite CTE-insert within trigger gives a syntax error(Sqlite CTE-INSERT INTERGER提供语法错误)
本文介绍了Sqlite CTE-INSERT INTERGER提供语法错误的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我的代码有问题,我似乎就是找不出问题是什么,所以我想我应该把它放在这里,希望其他人能发现错误(或确认我越来越怀疑有错误)。 因此,代码基本上等同于此,即使CTE-INSERT应该是完全合法的,并且当它不在触发器内时,我得到的样例代码也只有"error:ear"insert":syntic error"(错误:接近"插入":语法错误)。我正在使用Sqlite 3.8.7。
CREATE TABLE a (val INTEGER);
CREATE TABLE b (val INTEGER);
CREATE TRIGGER update_b AFTER INSERT ON a
BEGIN
WITH prev AS (
SELECT
0 AS val
)
INSERT INTO b(
val
)
SELECT
prev.val
FROM prev;
END;
谢谢!
推荐答案
documentation表示:
不能在CREATE触发器中使用WITH子句。
这篇关于Sqlite CTE-INSERT INTERGER提供语法错误的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:Sqlite CTE-INSERT INTERGER提供语法错误
基础教程推荐
猜你喜欢
- 从字符串 TSQL 中获取数字 2021-01-01
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01
- 带更新的 sqlite CTE 2022-01-01
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
- MySQL 5.7参照时间戳生成日期列 2022-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01
