mysql自增序列nextval并发_mysql 自增序列(转)

1:原理是在建立一个触发器TRIGGERtri_NewBH 在table插入时执行序列计算

mysql>CREATETABLEtb(BHCHAR(16),contentVARCHAR(20),`date`DATETIME,valINT);

Query OK,0rows affected (0.05sec)

mysql>mysql>mysql>DELIMITER $$

mysql>DROPTRIGGERIFEXISTStri_NewBH $$

Query OK,0rows affected,1warning (0.00sec)

mysql>mysql>CREATETRIGGERtri_NewBH BEFOREINSERTONtb->FOREACH ROW->BEGIN->DECLAREdtCHAR(8);->DECLAREbh_idCHAR(16);->DECLAREnumberINT;->DECLAREnew_bhVARCHAR(16);->->SETdt=DATE_FORMAT(CURDATE(),'%Y%m%d');->->SELECT->MAX(BH)INTObh_id->FROMtb->WHEREBHLIKECONCAT(dt,'%');->->IFbh_id=''ORbh_idISNULLTHEN->SETnew_bh=CONCAT(dt,'00000001');->ELSE->SETnumber=RIGHT(bh_id,8)+1;->SETnew_bh=RIGHT(CONCAT('00000000',number),8);->SETnew_bh=CONCAT(dt,new_bh);->ENDIF;->->SETNEW.BH=new_bh;->END$$

Query OK,0rows affected (0.09sec)

mysql>mysql>DELIMITER ;

mysql>INSERTINTOtb(content,`date`,val)VALUES('LiangCK','2009-05-11',20);

Query OK,1row affected (0.00sec)

mysql>INSERTINTOtb(content,`date`,val)VALUES('LiangCK','2009-05-11',20);

Query OK,1row affected (0.01sec)

mysql>INSERTINTOtb(content,`date`,val)VALUES('LiangCK',&#

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值