您现在的位置是:群英 > 数据库 > MySQL数据库
MySQL数据库怎么实现主键自动增长
Admin发表于 2022-05-09 18:00:442589 次浏览
这篇文章主要给大家介绍“MySQL数据库怎么实现主键自动增长”的相关知识,下文通过实际案例向大家展示操作过程,内容简单清晰,易于学习,有这方面学习需要的朋友可以参考,希望这篇“MySQL数据库怎么实现主键自动增长”文章能对大家有所帮助。


 

在mysql中,可以利用“AUTO INCREMENT”字段实现自动增加,该字段会在新记录插入表中时生成一个唯一的数字,默认开始值为1,每条新纪录递增1,语法为“字段名 数据类型 AUTO_INCREMENT”。

本教程操作环境:windows10系统、mysql8.0.22版本、Dell G3电脑。

mysql怎么实现自动增加

自动增长的作用:

问题:为数据表设置主键约束后,每次插入记录时,如果插入的值已经存在,会插入失败。

如何解决:为主键生成自动增长的值。

自动增长的语法:

字段名 数据类型 AUTO_INCREMENT;

使用须知:

1.一个表中只能有一个自动增长字段;

2.该字段的数据类型是整数类型;

3.必须定义为键,如 UNIQUE KEY、 PRIMARY KEY;

4.若为自动增长字段插入NULL、0、 DEFAULT或在插入时省略该字段,该字段就会使用自动增长值;

5.若插入的是一个具体值,则不会使用自动增长值;

6.自动增长值从1开始自增,每次加1

7.若插入的值大于自动增长的值,则下次插入的自动增长值会自动使用最大值加1;

8.若插入的值小于自动增长值,则不会对自动增长值产生影响;

9.使用 DELETE删除记录时,自动增长值不会减小或填补空缺.

自动增长使用示例:

--自动增长使用演示
Create Table my_auto(
id Int Unsigned Primary Key Auto_Increment,
username Varchar(20)
);
#查看
DESC my_auto;

自动增长使用演示:

#插入时省略id字段,将会使用自动增长值
Insert Into my_auto(username) Values('a');
#为id字段插入null,将会使用自动增长值
Insert Into my_auto Values(Null,'b');
#为id字段插入具体值6
Insert Into my_auto Values(6,'c');
#为id字段插入0,使用自动增长值
Insert Into my_auto Values(0,'d');
#查看
Select * From my_auto;

查看自动增长值:

#查看自动增长值
Show Create Table my_auto;

为现有的表修改或删除自动增长:

#修改自动增长值
Alter Table my_auto Auto_Increment=10;
#删除自动增长值
Alter Table my_auto Modify id Int Unsigned;
#重新为id添加自动增长值
Alter Table my_auto Modify id Int Unsigned Auto_Increment;

注意:

1.自动增长删除并重新添加后,自动增长的初始值会自动设为该列现有的最大值加1;

2.在修改自动增长值时,修改的值若小于该列见有的最大值,则修改不会生效。


以上就是关于“MySQL数据库怎么实现主键自动增长”的相关知识,感谢各位的阅读,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注群英网络,小编每天都会为大家更新不同的知识。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

标签: mysql自动增长
相关信息推荐
2022-05-17 11:53:29 
摘要:在mysql中,可以利用sum()函数对字段求和,该函数的作用就是返回数值列的总数,语法为“SELECT sum(求值的字段) FROM '表名'”。
2022-10-18 17:46:09 
摘要:本篇文章给大家带来了关于mysql的相关知识,其中主要为大家总结了一些MySQL中数据库优化的常见sql语句,文中的示例代码讲解详细,下面一起来看一下,希望对大家有帮助。
2022-05-16 11:35:25 
摘要:查询方法:1、使用“SHOW TABLE STATUS FROM `数据库名`;”语句,可列出指定数据库中所有表的信息,包括表类型;2、使用“SHOW CREATE TABLE `数据表名`;”语句,可列出指定数据表的信息,包括表类型。
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部