文章详情页
关于设计mysql中一个字段自增的函数。
浏览:117日期: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. javascript - 微信小程序 wx.downloadFile下载文件大小有限制吗2. mysql - 仅仅只是把单引号与反斜杠转义不用prepare statement能否避免sql注入?3. mysql在限制条件下筛选某列数据相同的值4. 新入手layuiadmin,部署到tp中。想用php自已写一个后台管理系统。5. javascript - 天猫首页首屏数据来源6. android - 安卓做前端,PHP做后台服务器 有什么需要注意的?7. php - 生产环境下,给MySQL添加索引,修改表结构操作,如何才能让线上业务不受影响?8. mysql - 拖拽重排序后怎么插入数据库?9. macOS Sierra 10.12 安装mysql 5.7.1出现错误10. mysql 获取时间函数unix_timestamp 问题?
排行榜
