SQLITE触发器这样创建不对吗?请教前辈

shier2817 2014-05-01 12:45:25
CREATE TRIGGER IF NOT EXISTS trigger_al_i BEFORE INSERT ON asset_lists
FOR EACH ROW
BEGIN
SELECT CASE
WHEN name = NEW.name THEN RAISE(ABORT, '新增资产与编号为 ' || lid || ' 的资产名称冲突。')
WHEN pinyin = NEW.pinyin THEN RAISE(ABORT, '新增资产与编号为 ' || lid || ' 的资产拼音冲突。') END
FROM asset_lists WHERE name = NEW.name OR pinyin = NEW.pinyin;
END;


总是提示我:near "||": syntax error

莫非 RAISE 中的消息只能是个简单的字符串,不可以拼接?不可以引用表中数据?

-------------------------------------------------------------------------
我只想问这种触发器该如何实现,请不要给出其他的解决方法,我知道 UNIQUE 这个字段就可以了,我这里只是写个简单的做测试,谢谢!
...全文
183 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
「已注销」 2014-05-05
  • 打赏
  • 举报
回复
貌似没人肯回复了。。。
「已注销」 2014-05-01
  • 打赏
  • 举报
回复
请帮帮我,灰常感谢!
「已注销」 2014-05-01
  • 打赏
  • 举报
回复
这个链接我早就搜索过了。。。 我百度和谷歌都翻了好几十页的,但是都没找到比较明确的关于 RAISE 函数中 错误消息 参数的说明,说的都是第一个参数的4种模式而已。。。 而所有搜索到的例子中,触发的错误消息都是比较简单的一句字符串,所以我现在比较倾向于我前面说的: RAISE 中的消息只能是个简单的字符串,不可以拼接,也不可以引用字段数据。 只不过没有官方的说法,我也想咨询官方,可第一自己英文太差,不太会问,第二sqlite也没个论坛,好像就有个邮箱,貌似咨询官方只能发邮件?
wwwwb 2014-05-01
  • 打赏
  • 举报
回复
参考一下 http://blog.sina.com.cn/s/blog_8c26f28301014qrm.html

2,209

社区成员

发帖
与我相关
我的任务
社区描述
其他数据库开发 其他数据库
社区管理员
  • 其他数据库社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧