发布
社区首页 >问答首页 >在现有的MySQL数据库上填充自动增量类型ID?

在现有的MySQL数据库上填充自动增量类型ID?
EN

Stack Overflow用户
提问于 2014-03-16 00:58:05
回答 2查看 317关注 0票数 0

我有一个现有的MySQL数据库,可以用PHP访问。大约有15,000条记录,我需要快速进入并更新刚刚添加的一个新的Design Number列。我需要迭代整个数据集,并将第一个记录的值设置为00001,下一个为00002,并一直递增到最后。我有代码到位,以确保所有新记录将有这一应用,但我需要更新现有的15,000记录快速。

有没有一种快速的方法在MySQL中实现这一点,而无需构建一个PHP脚本来快速填充所有的旧记录?

请记住,这不是MySQL中的常规自动增量,而是在SugarCRM中模拟该功能的自定义实现。

我需要迭代这张表..。

代码语言:javascript
代码运行次数:0
复制
SELECT designnumber_c FROM d1_designs_cstm

然后更新这个designnumber_c列,并为每个记录增加+1,同时维护一个00001 0填充

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-03-16 01:02:11

就像这样:

代码语言:javascript
代码运行次数:0
复制
mysql> SET @id := 0;
mysql> UPDATE d1_designs_cstm SET designnumber_c = LPAD(@id:=@id+1, 6, '0');
票数 3
EN

Stack Overflow用户

发布于 2014-03-16 02:35:37

通过https://stackoverflow.com/a/22431736/767881添加关于https://stackoverflow.com/users/1199612/patrick-savalle的更多信息

可以将新列定义为

代码语言:javascript
代码运行次数:0
复制
designnumber_c int(6) unsigned zerofill not null

在这方面:

  1. 您不需要显式地将零移到它。
  2. 您可以按实际值选择、更新、删除列,而不是按零填充值。

示例

代码语言:javascript
代码运行次数:0
复制
mysql> SET @id := 0;
mysql> UPDATE d1_designs_cstm 
    ->   SET designnumber_c = @id:=@id+1;
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22431706

复制
相关文章

相似问题

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