首页 / MYSQL / mysql编号生成_MySQL
mysql编号生成_MySQL
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql编号生成_MySQL,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1142字,纯文字阅读大概需要2分钟。
内容图文
![mysql编号生成_MySQL](/upload/InfoBanner/zyjiaocheng/580/0cf019f3899d46c19b711c3710facc7d.jpg)
DELIMITER $$ CREATE DEFINER=`root`@`localhost` FUNCTION `get_workNo`() RETURNS varchar(45) CHARSET utf8 BEGIN DECLARE newWorkNo varCHAR (45) ; DECLARE currentDate varCHAR (15) ;-- 当前日期,有可能包含时分秒 DECLARE maxNo INT DEFAULT 0 ; DECLARE oldWorkNo VARCHAR (25) DEFAULT '' ;-- 离现在最近的满足条件的订单编号 SELECT SUBSTRING(DATE_FORMAT(NOW(), '%Y%m'),3,6) INTO currentDate ; SELECT IFNULL(workNo, '') INTO oldWorkNo FROM operation_work WHERE SUBSTRING(workNo, 3, 4) = currentDate ORDER BY id DESC LIMIT 1 ; -- 有多条时只显示离现在最近的一条 IF oldWorkNo != '' THEN SET maxNo = CONVERT(SUBSTRING(oldWorkNo, -4), DECIMAL) ;-- SUBSTRING(oldOrderNo, -5):订单编号如果不为‘‘截取订单的最后5位 END IF ; SELECT CONCAT('TS', currentDate, LPAD((maxNo + 1), 4, '0')) INTO newWorkNo ; RETURN newWorkNo; END$$ DELIMITER ;
2、插入数据时的触发器
USE `it_system`; DELIMITER $$ CREATE DEFINER=`root`@`localhost` TRIGGER `operation_work_BINS` BEFORE INSERT ON `operation_work` FOR EACH ROW begin SET @workNo = get_workNo(); set NEW.workNo=@workNo; end
内容总结
以上是互联网集市为您收集整理的mysql编号生成_MySQL全部内容,希望文章能够帮你解决mysql编号生成_MySQL所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。
来源:【匿名】