文章详情页
关于设计mysql中一个字段自增的函数。
浏览:197日期:2022-06-10 17:40:44
问题描述
我有一个简单的表,有三个字段,tag_id,user_id,user_tag_id,我想当我插入一条记录(插入已知的tag_id和user_id)时,user_tag_id要在user_id=当前插入的user_id的条件下的自增1,这个怎么实现,是要写mysql的自定义函数么?
问题解答
回答1:DELIMITER $$DROP TRIGGER IF EXISTS after_insert_table $$CREATE TRIGGER after_insert_tableAFTER INSERT on tableFOR EACH ROWBEGIN update table t set t.user_tag_id = t.user_tag_id+1 where t.user_id=new.user_id ;END $$DELIMITER ;回答2:
如果只是新插入的记录中user_tag_id加1,可以分成两个sql语句:
首先计算user_id对应user_tag_id的最大值
select max(user_tag_id) + 1 from t1 where user_id = :user_id
然后把上个语句的返回值,放到insert语句中就可以了。
相关文章:
1. docker-compose中volumes的问题2. nignx - docker内nginx 80端口被占用3. python - Django ManyToManyField 字段数据在 admin后台 显示不正确,这是怎么回事?4. docker api 开发的端口怎么获取?5. weex - Android 原生Vue.js 使用 justify-content: flex-end; 不起作用6. node.js - antdesign怎么集合react-redux对input控件进行初始化赋值7. angular.js - Angularjs中点击事件传递参数 给class更换样式。8. angular.js - angular内容过长展开收起效果9. docker images显示的镜像过多,狗眼被亮瞎了,怎么办?10. php由5.3升级到5.6后,登录网站,返回的是php代码,不是登录界面,各位大神有知道的吗?
排行榜

网公网安备