有一个需求是合同ID是自动增长的,规律是
公司英文缩写+4位整数+/+年份后2位
我使用如下查询获取这些数据
$result = mysql_query("SELECT SUBSTRING(`bill_id`,3,4) AS `bid` FROM `tab` WHERE `bill_id` REGEXP '^XX[0-9]{4}\/".date('y')."$' ORDER BY `bid`") or die("write log file");
因为还有一个需求是如果其中有个合同被删除,则该合同ID会被填补
比如建立了合同ID为"XX0010/11"、"XX0011/11"合同后,如果删除了"XX0010/11"合同(未通过审核的合同才允许删除),则下次再建立合同时,合同号为"XX0010/11"而非"XX0012/11"
所以获取所有该年份的合同ID,之后再处理,看看最大合同ID内是否有空的ID,如果没有则使用最大合同ID+1
新建立合同号是在用户提交新合同数据后才后台生成合同ID,生成后马上写入到数据库
现在的问题是,偶尔会出现获取回来的数据不完整,比如
数据库中现在最大的合同ID为 XX0180/11(数据库返回180条记录),而且中间没有空的合同ID,照理来说新建立的合同应该是XX0181/11
但.......执行上面的数据库查询后,获取回来的既然是178条记录,最大的合同ID为 XX0178/11,则新建立的合同ID为 XX0179/11,结果导致数据库唯一约束错误(bill_id建立了唯一约束)
但这错误并不是每次都出现,几率很小,大概建立100次合同会出现1、2次(也并非100次就出现,部署上项目后倒是没出现过,也可能是他们没说,但至少我自己在调试的时候发现有这问题),而且比如我这次建立的时候出错,提示唯一约束错误后,刷新页面,再建立一次就成功了...
因为我是在自己机子上调试的,apache访问日志里也只有我自己访问的记录,mysql数据库只允许本地登录,所以不存在别人插入新的数据导致我的数据插入错误的情况。
这会是PHP的问题还是mysql的问题呢??
如果说是mysql问题,但比如XX0180/11这些数据在查询之前就已经存在很久了,而且也没有事务在运行,所以怎么说执行查询后没理由查询不到XX0180/11这条数据