Mysql 如何创建触发器来进行字段串联
我有一张这样的桌子:Mysql 如何创建触发器来进行字段串联,mysql,sql,database,sql-update,Mysql,Sql,Database,Sql Update,我有一张这样的桌子: user ---------------------------------------- id | first_name | last_name | full_name ---------------------------------------- 我想写一个触发器,它将把名字和姓氏转换成全名 我试过以下方法: delimiter | create trigger fullname after insert on user for each row begin upd
user
----------------------------------------
id | first_name | last_name | full_name
----------------------------------------
我想写一个触发器,它将把名字和姓氏转换成全名
我试过以下方法:
delimiter |
create trigger fullname after insert on user
for each row
begin
update user set full_name=(select concat(first_name,last_name) from user where id=new.id)where id=new.id;
end;
|
将数据插入用户表时显示此错误:
#1442-无法更新存储函数/触发器中的表“user”,因为调用此存储函数/触发器的语句已使用该表。
在触发INSERT触发器时,无法更改表。但是,您可以在插入记录之前创建触发器
DELIMITER |
CREATE TRIGGER `fullname` BEFORE INSERT ON `user`
FOR EACH ROW
BEGIN
SET NEW.full_name = CONCAT(NEW.first_name, ' ', NEW.last_name);
END |
DELIMITER ;
对于您的情况,我建议您使用computed column而不是trigger,因为您需要为insert/update创建触发器 希望这能帮助你
检查一下:哎呀,我的错误,在插入记录之前创建触发器的逻辑没有在我脑海中出现……它起作用了:)谢谢,先生。。。!!!
create table [users]
( id int identity(1,1),
First_Name varchar(100),
Last_Name varchar(100),
Full_Name as concat(First_Name,' ', Last_Name) persisted
)
Insert into [users]
select 'Bob', 'Ryan'
select * from [users]
update users
set First_Name = 'Michael'
where id=1
select * from users