我正在使用mysql/php。
我的桌子看起来像
id (int autoincrement)
voucher(varchar 25)我正在生成代金券代码,代码是:
使用php执行此操作的明显问题是,我必须执行一个select,获取下一个自动增量值,计算代码insert,到那时可以插入另一个行。
我想做的是,
做insert into vouchers (voucher) value('64352')并让它生成我的其余部分。
我该怎么做?功能/触发?
发布于 2011-05-12 01:00:01
如果您正在使用InnoDB,那么一个简单的解决方法就是使用您现有的代码并将其包装到一个MySQL事务中。即在伪码中:
mysql_query("START TRANSACTION");
# get next autoincrement value into: $next
# do your INSERT query
# get the actual last inserted ID into: $actual
if ($next === $actual) {
mysql_query("COMMIT");
} else {
mysql_query("ROLLBACK");
# and raise an Exception or return an error
}编辑/添加:
既然你提到了导火索,我就调查了一下,并相信这是可行的。几个问题。
不管怎么说,触发器是这样的:
delimiter //
CREATE TRIGGER make_voucher_code BEFORE INSERT ON vouchers
FOR EACH ROW
BEGIN
SET @vcount = @vcount + 1;
SET NEW.voucher = CONCAT(
NEW.voucher,
CAST(@vcount AS CHAR),
Luhn(CONCAT(NEW.voucher, CAST(@vcount AS CHAR))));
END;
//
delimeter ;然后,按照您的建议,在插入的内容中只添加“64352”。扳机会附加其余的。
就个人而言,除非您或其他人能够更好地解决自动增量/@vcount问题,否则我仍然更喜欢执行MySQL事务,这将比保持所有应用程序代码都保持原子化和将所有应用程序代码保持在PHP中的工作做得更好。
发布于 2011-05-12 01:02:54
或执行值为0的插入,然后获取insert id,计算值并更新记录。
https://stackoverflow.com/questions/5972203
复制相似问题