开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 1311|回复: 16
收起左侧

[完成] 易语言怎么实现这种MYSQL数据库自增编号

 关闭 [复制链接]
结帖率:100% (10/10)
发表于 2023-11-20 17:03:20 | 显示全部楼层 |阅读模式   广东省东莞市
100精币
有会的大神帮忙写个模块,谢谢


补充内容 (2023-11-20 17:22):
易语言这边增加之前要先读入数据库中的最后一个值,每次在这个值上+1,如果多人同时操作还要防止与别人的录入的数据相同

补充内容 (2023-11-20 19:46):
附数据库在12楼
12.png

最佳答案

查看完整内容

[mw_shl_code=sql,true]-- 创建触发器 DELIMITER // CREATE TRIGGER employees_before_insert BEFORE INSERT ON `员工表` FOR EACH ROW BEGIN DECLARE current_year INT; DECLARE last_job_number INT; SET current_year = YEAR(CURRENT_TIMESTAMP); -- 获取最后一条记录的年份 SELECT YEAR(created_at) INTO last_job_number FROM `员工表` ORDER BY id DESC LIMIT 1; -- 如果年份 ...
结帖率:100% (10/10)

签到天数: 10 天

发表于 2023-11-20 17:03:21 | 显示全部楼层   湖北省荆州市
[SQL] 纯文本查看 复制代码
-- 创建触发器
DELIMITER //
CREATE TRIGGER employees_before_insert
BEFORE INSERT ON `员工表`
FOR EACH ROW
BEGIN
    DECLARE current_year INT;
    DECLARE last_job_number INT;
    SET current_year = YEAR(CURRENT_TIMESTAMP);
    
    -- 获取最后一条记录的年份
    SELECT YEAR(created_at) INTO last_job_number
    FROM `员工表`
    ORDER BY id DESC
    LIMIT 1;
    
    -- 如果年份改变,重置编号为1
    IF last_job_number < current_year THEN
        SET NEW.job_number = CONCAT('DD', current_year, '00001');
    ELSE
        -- 否则,在最后一条记录的基础上自增编号
        SET NEW.job_number = CONCAT('DD', current_year, LPAD(SUBSTRING_INDEX(last_job_number, current_year, -1) + 1, 5, '0'));
    END IF;
END;
//
DELIMITER ;

评分

参与人数 1荣誉 +1 收起 理由
笨潴 + 1 热心帮助他人,荣誉+1,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:100% (11/11)

签到天数: 11 天

发表于 2023-11-20 17:15:25 | 显示全部楼层   新疆维吾尔自治区石河子市
写个触发器试试吧
回复

使用道具 举报

签到天数: 13 天

发表于 2023-11-20 17:15:31 | 显示全部楼层   广东省广州市
能自动赚钱更好 !  自己定义规格录入就好了。
回复

使用道具 举报

结帖率:100% (10/10)
 楼主| 发表于 2023-11-20 17:19:30 | 显示全部楼层   广东省东莞市
白陌陌 发表于 2023-11-20 17:15
写个触发器试试吧

不会写哦,会的话可以麻烦帮忙写个例子吗
回复

使用道具 举报

结帖率:60% (3/5)

签到天数: 13 天

发表于 2023-11-20 17:19:46 | 显示全部楼层   天津市天津市
写个循环不就行了 在取个当前时间
回复

使用道具 举报

结帖率:100% (109/109)

签到天数: 2 天

发表于 2023-11-20 17:30:45 | 显示全部楼层   湖北省武汉市
是这样吗  

VX截图_20231120173008.png
回复

使用道具 举报

结帖率:100% (109/109)

签到天数: 2 天

发表于 2023-11-20 17:38:09 | 显示全部楼层   湖北省武汉市
易语言这边增加之前要先读入数据库中的最后一个值,每次在这个值上+1,如果多人同时操作还要防止与别人的录入的数据相同

.版本 2
.支持库 mysql

句柄 = 连接MySql ()
执行SQL语句 (句柄, “SET NAMES GBK”)
执行SQL语句 (句柄, “SELECT * FROM 表名 ORDER BY 工号 DESC LIMIT 1;”)
记录集句柄 = 取记录集 (句柄)
读字段值 (记录集句柄, “ID”, 工号)

工号 = 上面图片写的

然后在 insert 这个工号进去就






补充内容 (2023-11-20 17:38):
就可以啦,不知道是不是你想要的
回复

使用道具 举报

结帖率:97% (97/100)

签到天数: 13 天

发表于 2023-11-20 18:05:57 | 显示全部楼层   河南省郑州市
INSERT INTO employees (job_number)
VALUES (CONCAT('DD', YEAR(CURRENT_DATE()), LPAD((SELECT COUNT(*) FROM employees) + 1, 6, '0')));
回复

使用道具 举报

结帖率:100% (10/10)
 楼主| 发表于 2023-11-20 19:27:00 | 显示全部楼层   广东省东莞市
kurt 发表于 2023-11-20 17:38
.版本 2
.支持库 mysql

可以帮忙写个源码文件出来吗
这种分几段的只要有一个标点符号出错我都看不出来错在哪里了
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表