扫码关注官方订阅号
我有一个简单的表,有三个字段,tag_id,user_id,user_tag_id,我想当我插入一条记录(插入已知的tag_id和user_id)时,user_tag_id要在user_id=当前插入的user_id的条件下的自增1,这个怎么实现,是要写mysql的自定义函数么?
DELIMITER $$ DROP TRIGGER IF EXISTS after_insert_table $$ CREATE TRIGGER after_insert_table AFTER INSERT on table FOR EACH ROW BEGIN update table t set t.user_tag_id = t.user_tag_id+1 where t.user_id=new.user_id ; END $$ DELIMITER ;
如果只是新插入的记录中user_tag_id加1,可以分成两个sql语句:
首先计算user_id对应user_tag_id的最大值
select max(user_tag_id) + 1 from t1 where user_id = :user_id
然后把上个语句的返回值,放到insert语句中就可以了。
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
扫描下载App
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
如果只是新插入的记录中user_tag_id加1,可以分成两个sql语句:
首先计算user_id对应user_tag_id的最大值
然后把上个语句的返回值,放到insert语句中就可以了。