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