首页
学习
活动
专区
圈层
工具
发布

难插入
EN

Stack Overflow用户
提问于 2011-05-12 00:50:40
回答 2查看 123关注 0票数 0

我正在使用mysql/php。

我的桌子看起来像

代码语言:javascript
复制
id (int autoincrement)  
voucher(varchar 25)

我正在生成代金券代码,代码是:

  • 1随机数(如64)
  • 1固定数目(如352)
  • id字段值(1,2,3,4,5.)
  • 1校验位(luhn算法)。

使用php执行此操作的明显问题是,我必须执行一个select,获取下一个自动增量值,计算代码insert,到那时可以插入另一个行。

我想做的是,

insert into vouchers (voucher) value('64352')并让它生成我的其余部分。

我该怎么做?功能/触发?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-05-12 01:00:01

如果您正在使用InnoDB,那么一个简单的解决方法就是使用您现有的代码并将其包装到一个MySQL事务中。即在伪码中:

代码语言:javascript
复制
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
}

编辑/添加:

既然你提到了导火索,我就调查了一下,并相信这是可行的。几个问题。

  1. 从触发器中访问“下一个自动增量ID”.我不知道有什么“好”的方法。在INSERT查询中,您只能访问新的而不是旧的(现有的行)值(请参阅触发语法)。在这个示例中,我要做的就是在服务器上维护一个单独的计数器@vcount。若要将此值初始化为当前的ID,只需执行"SET @vcount =42“;
  2. Luhn算法您必须将其实现为SQL函数。下面是,您可以从SQL中获得一个Luhn验证器。或者,您可以使用本地MySQL函数(如MD5 )散列/校验和(如果需要简短的凭单代码,则只使用第一个X字符)。无论如何,你需要做一个散列函数.我用下面的"Luhn“。

不管怎么说,触发器是这样的:

代码语言:javascript
复制
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中的工作做得更好。

票数 1
EN

Stack Overflow用户

发布于 2011-05-12 01:02:54

或执行值为0的插入,然后获取insert id,计算值并更新记录。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5972203

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档