為了測試,表中僅添加了兩列,分別是主鍵id 和 name列,兩列都為varchar類型。
備注:id內(nèi)容格式為 BHXXXX,如:BH0001
因?yàn)橹麈Iid不是int類型,想實(shí)現(xiàn)自動自增功能,使用內(nèi)置的方法肯定是行不通的,所以,使用了復(fù)雜的查詢方法及拼接方式,此方法雖然比較笨,但測試還是可以通過的。
大致思路:在MySql中新建表時(shí),可以創(chuàng)建觸發(fā)器為id進(jìn)行自增。
詳細(xì)思路:
1、使用查詢語句查出表中最后一條數(shù)據(jù)的id,語句:select id from user order by id desc limit 1 得到結(jié)果 BH0001
2、使用substring函數(shù)截取最后一條BHXXXX中數(shù)字部分:
SELECT substring(id,3,4) from user where id=(select id from user order by id desc limit 1) 得到結(jié)果 0001
其中,3表示從第3位進(jìn)行截取,4表示截取長度
3、使用concat語句進(jìn)行字符串連接
concat('BH',(SELECT substring(id,3,4) from user where id=(select id from user order by id desc limit 1) +1));
我剛開始認(rèn)為到這一步的時(shí)候,只要給以上結(jié)果 +1 ,然后使用concat語句連接字符串就可以了,但是,得到的結(jié)果并不是我想象中的 BH0002,而是BH2,所以,在進(jìn)行字符串連接之前,得將數(shù)字2進(jìn)行填充,使用LPAD函數(shù),最終結(jié)果如下:
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表示填充內(nèi)容。
觸發(fā)器完整語句:
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為觸發(fā)器名稱,user為表名,結(jié)束!