首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何强制MySQL将0作为有效的自动增量值

如何强制MySQL将0作为有效的自动增量值
EN

Stack Overflow用户
提问于 2009-07-17 10:20:44
回答 1查看 72.2K关注 0票数 78

长话短说,我有一个想要作为skel样式文件导入的SQL文件,因此这将以编程的方式重复执行。我可以随心所欲地编辑SQL文件,但我不想接触应用程序本身。

此应用程序使用userid = 0表示匿名用户。它在数据库中也有一个相关的(空白)条目来表示这个“用户”。因此,我的skel.sql中的代码行如下所示:

代码语言:javascript
复制
INSERT INTO `{{TABLE_PREFIX}}users` VALUES (0, '', '', '', 0, 0, 0, '', '', 0, 0, 0, 0, 0, NULL, '', '', '', NULL);

这样做的问题是,uid是一个auto_increment字段,从技术上讲,0是一个无效值。或者至少,如果您将其设置为0,您基本上就是在告诉MySQL,“请将下一个id插入到这个字段中。”

现在,我想我可以把一个INSERT然后一个UPDATE查询放到我的SQL文件中,但是有没有一种方法可以告诉MySQL,是的,我真的想把0插入到这个字段中?

EN

回答 1

Stack Overflow用户

发布于 2015-07-01 08:31:05

如果您不想处理mysql变量,这里有一个有用的技巧:

代码语言:javascript
复制
INSERT INTO `{{TABLE_PREFIX}}users` VALUES (-1, '', '', '', 0, 0, 0, '', '', 0, 0, 0, 0, 0, NULL, '', '', '', NULL);

然后

代码语言:javascript
复制
UPDATE `{{TABLE_PREFIX}}users` SET id = 0 where id = -1;

显然,这假设您使用的是有符号整数,而不是表ids的负值。

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

https://stackoverflow.com/questions/1142472

复制
相关文章

相似问题

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