【MYSQL】mysql约束---自增长约束(auto_increment)

1、概念

在Mysql中,当主键为自增长后,这个主键的值就不再需要用户输入数据了,而由数据库系统根据定义自动赋值。每增加一条记录,主键会自动以相同的步长进行增长。

注意:自增长约束通常与主键放在一起使用。

通过给字段添加auto_increment属性来实现主键的增长。

2、语法

字段名 数据类型 primary key auto_increment

3、操作

示例:

注意:自增长约束默认情况下主键的值时从1开始的。

示例;

4、特点

(1)默认情况下,auto_increment的初识值是1,每新增一条记录,字段值会自动加1

(2)一个表只能有一个字段使用auto_increment约束,且该字段必须有唯一索引,以避免序号重复(即为主键或主键的一部分)

(3)auto_increment约束的字段必须具备NOT NULL属性。

(4)auto_increment约束的字段只能是整数类型。(TINYINT, SMALLINT, INT, BIGINT等)

(5)auto_increment约束字段的最大值受该字段的数据类型约束,如果达到上限,auto_increment就会失效。

5、指定自增字段初识值:

如果第一条记录设置了该字段的初识值,那么新增加的记录就会从这个初识值开始自增。例如:如果表中插入的第一条记录的id值设置为5,那么再插入记录时,id值就会从5开始开始往上增加。

(1)创建表时指定

例如:

create table t_user2(

id int primary key auto_increment,

name varchar(200)

)auto_increment=100;

#往表t_user2中插入数据时,id值会从100开始。

示例:

(2)创建表之后指定

例如:

create table user(

id int primary key auto_increment,

name varchar(20)

);

alter table user auto_increment=120;

示例;

(3)delete 和truncate在删除后自增列的变化

1))delete数据之后,自动增长从断电开始。即:delete删除数据之后,自增长还是在最后一个值基础上加1.

示例:

delete前:

delete后:

2))truancate数据之后,自动增长从默认起始值开始,即:truncate删除之后,自增长从1开始。

示例:

truncate前:

truncate后;

总结:

在有起始值的情况,delete删除数据之后自增长还是在最后一个值基础上加1,而truncate删除数据之后,自增长从1开始。

相关推荐
Project_Observer几秒前
Zoho Projects自动化:状态变更时自动创建依赖任务
linux·数据库·windows
heimeiyingwang10 分钟前
Chroma(轻量级向量数据库) 与 MongoDB(文档型 NoSQL 数据库) 的细节拆解
数据库·mongodb·nosql
宇擎智脑科技12 分钟前
SurrealDB:面向AI原生应用的新一代多模型数据库深度解析
数据库·人工智能·ai-native
IT_Octopus15 分钟前
AI 工程 生产级别 向量数据库 Milvus 部署架构&多租户方案&节点流程简单总结
数据库·架构·milvus
xuzhiqiang072416 分钟前
【Flask】四、flask连接并操作数据库
数据库·python·flask
TDengine (老段)28 分钟前
TDengine IDMP 数据可视化 6. 资产列表
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
luoluoal32 分钟前
基于python的医疗知识图谱问答系统(源码+文档)
python·mysql·django·毕业设计·源码
ℳ₯㎕ddzོꦿ࿐39 分钟前
[特殊字符] 【踩坑记录】没调 startPage(),SQL 却被自动分页了?
数据库·sql
I'm Jie39 分钟前
【已解决】SqlAlchemy 插入 MySQL JSON 字段时 None 变为 ‘null‘ 字符串,WHERE IS NULL 失效
数据库·python·mysql·json·fastapi·sqlalchemy
之歆40 分钟前
MySQL 数据库理论、安装、查询、事务与备份恢复
数据库·mysql·adb