【MySQL中auto_increment有什么作用?】
问题来源
很多时候,MySQL语句中会出现【auto_increment】这个词汇,大多数时候,表都是自动生成的,刚开始学习MySQL数据库时会学习到,后来,渐渐地可能会忘记,那么这个语句的作用到底是什么意思?下面,来汇总一下:
解释
auto_increment是用于主键自动增长
的,从1开始增长,当你把第一条记录删除时,再插入第二条数据时,主键值是2,不是1。
例如:
create table test
(
id
int(10) not null auto_increment, – 表示自增列
name
varchar(20) not null,
primary key(id
)
)
auto_increment = 1; – 表示自增起始大小-- 这样就可以创建一个表test
,id为自增列
– 执行语句 insert into test (name
) values (‘名字’);
– 就可以插入一行数据为: 1 ‘名字’
注意事项
在使用AUTO_INCREMENT时,应注意以下几点:
1
、AUTO_INCREMENT是数据列的一种属性,只适用于整数类型
数据列。
2
、设置AUTO_INCREMENT属性的数据列应该是一个正数序列
,所以应该把该数据列声明为UNSIGNED,这样序列的编号个可增加一倍。
3
、AUTO_INCREMENT数据列必须有唯一索引
,以避免序号重复(即是主键或者主键的一部分)。
AUTO_INCREMENT数据列必须具备NOT NULL
属性。
4
、AUTO_INCREMENT数据列序号的最大值受该列的数据类型约束,如TINYINT数据列的最大编号是127,如加上UNSIGNED,则最大为255。一旦达到上限,AUTO_INCREMENT就会失效。
5
、当进行全表删除时,MySQL AUTO_INCREMENT会从1重新开始编号。
这是因为进行全表操作时,MySQL(和PHP搭配之最佳组合)实际是做了这样的优化操作
:先把数据表里的所有数据和索引删除,然后重建数据表。
如果想删除所有的数据行又想保留序列编号信息,可这样用一个带where的delete命令以抑制MySQL(和PHP搭配之最佳组合)的优化:delete from table_name where 1;
可用last_insert_id()获取刚刚自增过的值。
说明:部分内容来自搜索整理,目的是为了记录总结,学习使用~
相关文章
- MySQL的普通索引和唯一索引到底什么区别?
- 优化MySQL性能的几种方法-总结
- mysql出生日期转成年龄
- macOS安装Mysql数据库
- android开发指南!漫谈MySQL权限安全,面试必会
- Entity Framework with MySQL 学习笔记一(拦截)
- MySQL 备份恢复(导入导出)单个 innodb表
- mysql修改数据库密码
- mysql 创建数据库 并设置utf8格式
- [转] MySQL 的 MRR 到底是什么?
- 【ChatGPT】我同时问 ChatGLM / Sage / ChatGPT :MySQL 添加索引之后 数据库做了些什么? 看看它们分别怎么回答……
- mysql_real_escape_string和mysql_escape_string有什么本质的区别,有什么用处,为什么被弃用?
- mysql shell 脚本备份
- 2023-03-08 mysql-子查询优化-in转换为exists-分析
- 谈谈什么是MySQL的表空间?
- MySQL中的单行函数①
- [ 数据库 ] MySQL 入门到放弃(五) --- MySQL 函数
- 异构平台同步(mysql-->oracle)
- 最好用的Mysql数据库客户端Sequel Pro使用及崩溃解决方案
- mysql表分区和分表的实现方式几种以及区别,什么时候用
- [转载]什么是mysql的慢查询
- MySQL远程登陆错误
- MYSQL 什么时候用单列索引?什么使用用联合索引?(收集)
- 【mysql我能讲两小时034】purge操作有什么作用?
- 【mysql】delete,drop,truncate区别是什么?
- 【mysql我能讲两小时019】什么是全文索引?