专业网站建设品牌,十四年专业建站经验,服务6000+客户--广州京杭网络
免费热线:400-683-0016      微信咨询  |  联系我们

mysql自连接查询,数据库中varchar类型怎么自增_数据库

当前位置:网站建设 > 技术支持
资料来源:网络整理       时间:2023/3/5 19:18:08       共计:3595 浏览
mysql自连接查询,数据库中varchar类型怎么自增?

为了测试,表中仅添加了两列,分别是主键id 和 name列,两列都为varchar类型。

备注:id内容格式为 BHXXXX,如:BH0001

因为主键id不是int类型,想实现自动自增功能,使用内置的方法肯定是行不通的,所以,使用了复杂的查询方法及拼接方式,此方法虽然比较笨,但测试还是可以通过的。

大致思路:在MySql中新建表时,可以创建触发器为id进行自增。

详细思路:

1、使用查询语句查出表中最后一条数据的id,语句:select id from user order by id desc limit 1 得到结果 BH0001

2、使用substring函数截取最后一条BHXXXX中数字部分:

SELECT substring(id,3,4) from user where id=(select id from user order by id desc limit 1) 得到结果 0001

其中,3表示从第3位进行截取,4表示截取长度

3、使用concat语句进行字符串连接

concat('BH',(SELECT substring(id,3,4) from user where id=(select id from user order by id desc limit 1) +1));

我刚开始认为到这一步的时候,只要给以上结果 +1 ,然后使用concat语句连接字符串就可以了,但是,得到的结果并不是我想象中的 BH0002,而是BH2,所以,在进行字符串连接之前,得将数字2进行填充,使用LPAD函数,最终结果如下:

concat('BH',lpad(((SELECT substring(id,3,4) from user where id=(select id from user order by id desc limit 1))+1),4,0));

其中,4表示填充长度,0表示填充内容。

触发器完整语句:

CREATE TRIGGER `T` BEFORE INSERT ON `user`

FOR EACH ROW begin\nset new.id=concat('SH',lpad(((SELECT substring(id,3,4) from user where id=(select id from user order by id desc limit 1))+1),4,0));

end;

其中,大写T为触发器名称,user为表名,结束!

版权说明:
本网站凡注明“广州京杭 原创”的皆为本站原创文章,如需转载请注明出处!
本网转载皆注明出处,遵循行业规范,如发现作品内容版权或其它问题的,请与我们联系处理!
欢迎扫描右侧微信二维码与我们联系。
·上一条:化工厂管道图纸怎么看_数据库 | ·下一条:目前在做设计工作_数据库

Copyright © 广州京杭网络科技有限公司 2005-2025 版权所有    粤ICP备16019765号 

广州京杭网络科技有限公司 版权所有