mysql下创建触发器碰到的问题-问答-阿里云开发者社区-阿里云

开发者社区> 落地花开啦> 正文

mysql下创建触发器碰到的问题

2016-02-13 13:40:49 1803 1

数据库存在使用如下语句创建的一个数据表:
create table tb_name (t_id int, t_name varchar(20));
请创建一个触发器,实现无论用户向表中添加什么数据字段,t_name 的内容都是"HelloWorld".
我的mysql语句如下:
`CREATE TRIGGER ins_su BEFORE INSERT ON tb_name FOR EACH ROW
INSERT INTO tb_name SET t_name = "HelloWorld";`
但是在向t_id 插入一个数据时:
INSERT INTO tb_name (t_id) VALUES (1);
报出如下错误:
Can't update table 'tb_name' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.
不是太明白错误原因,不知道正确的语句如何写?麻烦哪位高手解释一下

取消 提交回答
全部回答(1)
  • 落地花开啦
    2019-07-17 18:41:56

    你在INSERT的触发器里又执行一个INSERT,那这个INSERT又会触发触发器,所以就死循环了,这样不行。
    另外mysql中,如果一个表在触发器中是不能改变这个表的状态的。
    要改变插入的值,你只要写new.t_name= "HelloWorld" 就行了。

    0 0
相关问答

17

回答

【大咖问答】对话PostgreSQL 中国社区发起人之一,阿里云数据库高级专家 德哥

阿里ACE 彭飞 2019-07-10 09:36:10 963840浏览量 回答数 17

145

回答

【新手入门】云服务器linux使用手册

fanyue88888 2012-11-26 17:14:18 157051浏览量 回答数 145

8

回答

OceanBase 使用动画(持续更新)

mq4096 2019-02-20 17:16:36 333809浏览量 回答数 8

22

回答

爬虫数据管理【问答合集】

我是管理员 2018-08-10 16:37:41 146753浏览量 回答数 22

2

回答

mySQL数据库报错You have an error in your SQL syntax

落地花开啦 2016-02-14 16:09:24 126219浏览量 回答数 2

38

回答

安全组详解,新手必看教程

我的中国 2017-11-30 15:23:46 256840浏览量 回答数 38

21

回答

请教一下数据量有100万条左右要什么配置?

易网网络 2013-03-27 15:18:02 192316浏览量 回答数 21

249

回答

阿里云LNAMP(Linux + Nginx + Apache + MySQL + PHP)环境一键安装脚本

云代维 2014-02-14 15:26:06 302568浏览量 回答数 249

97

回答

Redhat/CentOS一键安装web环境全攻略

xiaofanqie 2011-08-11 14:51:38 123191浏览量 回答数 97

2

回答

区域选择帮助

fanyue88888 2012-12-07 15:54:30 203985浏览量 回答数 2
+关注
落地花开啦
喜欢技术,喜欢努力的人
0
文章
7824
问答
推荐问答
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载