网站首页 > 博客文章 正文
1.为什么需要自增
为数据表设置主键约束后,每次插入记录时,如果插入的值已经存在,会插入失败。为主键生成自动增长的值可以解决这种问题。
2.语法
字段名 数据类型 AUTO_INCREMENT
3.注意
- 一个表中只能有一个自动增长字段
- 该字段的数据类型是整数类型
- 必须定义为键
- 若为自动增长字段插入NULL、0、DEFAULT或在插入时省略该字段,该字段就会使用自动增长值;
- 若插入的是一个具体值,则不会使用自动增长值
- 自动增长值从1开始自增,每次加1。
- 若插入的值大于自动增长的值,则下次插入的自动增长值会自动使用最大值加1;
- 若插入的值小于自动增长值,则不会对自动增长值产生影响。
- 使用DELETE删除记录时,自动增长值不会减小或填补空缺。
4.演示
CREATE DATABASE mahaiwuji;
USE mahaiwuji;
CREATE TABLE student (
sid INT PRIMARY KEY AUTO_INCREMENT,
sname VARCHAR (32)
) ENGINE = INNODB DEFAULT CHARSET = utf8;
INSERT INTO student(sname) VALUES ('码海无际1');
INSERT INTO student VALUES (0,'码海无际2');
INSERT INTO student VALUES (4,'码海无际3');
INSERT INTO student(sname) VALUES ('码海无际4');
INSERT INTO student VALUES (3,'码海无际3');
DELETE FROM student WHERE sid=5;
INSERT INTO student(sname) VALUES ('码海无际4');
5.查看自动增长值
语法
SHOW CREATE TABLE student;
运行结果
CREATE TABLE `student` (
`sid` int(11) NOT NULL AUTO_INCREMENT,
`sname` varchar(32) DEFAULT NULL,
PRIMARY KEY (`sid`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8
6.修改自动增长
ALTER TABLE student AUTO_INCREMENT = 10;
INSERT INTO student(sname) VALUES ('码海无际5');
7.删除自动增长
ALTER TABLE student MODIFY sid INT;INSERT INTO student VALUES (11,'码海无际6');
-- 下面这行无法运行,因为自增被删除,必须手动插入主键
INSERT INTO student(sname) VALUES ('码海无际7');
8.添加自动增长
ALTER TABLE student MODIFY sid INT UNSIGNED AUTO_INCREMENT;
INSERT INTO student(sname) VALUES ('码海无际7');
猜你喜欢
- 2024-09-29 MySQL实战第14篇:在约束完整性下,工作中,如何设计表的结构?
- 2024-09-29 谈下最近开发中用了一下Mysql的set字段类型
- 2024-09-29 软件测试必备之数据库知识(软件测试数据库面试题及答案2020)
- 2024-09-29 越晚搞懂 MySQL JSON 数据类型,你就越吃亏
- 2024-09-29 主键简介1(主键是什么)
- 2024-09-29 资深开发竟然不清楚int(1)和int(10)的区别
- 2024-09-29 面试突击59:一个表中可以有多个自增列吗?
- 2024-09-29 MySQL实战——表结构设计之数字类型
- 2024-09-29 性能测试告诉你 mysql 数据库存储引擎该如何选?
- 2024-09-29 java常见疑难面试题及答案(阿里、蚂蚁、百度、美团)(三)
你 发表评论:
欢迎- 最近发表
-
- 给3D Slicer添加Python第三方插件库
- Python自动化——pytest常用插件详解
- Pycharm下安装MicroPython Tools插件(ESP32开发板)
- IntelliJ IDEA 2025.1.3 发布(idea 2020)
- IDEA+Continue插件+DeepSeek:开发者效率飙升的「三体组合」!
- Cursor:提升Python开发效率的必备IDE及插件安装指南
- 日本旅行时想借厕所、买香烟怎么办?便利商店里能解决大问题!
- 11天!日本史上最长黄金周来了!旅游万金句总结!
- 北川景子&DAIGO缘定1.11 召开记者会宣布结婚
- PIKO‘PPAP’ 洗脑歌登上美国告示牌
- 标签列表
-
- ifneq (61)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)