千家信息网

mysql 自增量与唯一性约束

发表于:2024-12-12 作者:千家信息网编辑
千家信息网最后更新 2024年12月12日,当一张数据表经过多次的删除操作后,它的自增值列通过会很混乱,不美观,这时就需要我们对它进行重新排序,让他从新从1开始。操作方法:先删除数据表中的原id字段,然后再重新建立id字段删除id字段:alte
千家信息网最后更新 2024年12月12日mysql 自增量与唯一性约束

当一张数据表经过多次的删除操作后,它的自增值列通过会很混乱,不美观,这时就需要我们对它进行重新排序,让他从新从1开始。


操作方法:先删除数据表中的原id字段,然后再重新建立id字段


删除id字段:

alter table bumen drop id;


重建字段:

ALTER TABLE bumen ADD id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY FIRST ;


--INT UNSIGNED 无符号整数(纯数字),FIRST 在表首插入,默认在表尾插入


-------------------------------------------------------------------------------------------


自定义自增值

设置自增值从50开始:


create table bumen(id int not null primary key auto_increment) auto_increment=50,charset=gbk; --指定语名要放在字段的括号之外


修改自增值从100开始:

ALTER TABLE bumen AUTO_INCREMENT = 100; --建表后进行更改定


-------------------------------------------------------------------------------------------


建立一张部门表,包含id序号,部门名称,管理人三个字段:


CREATE TABLE bu5 (

id INT(5) UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,

NAME CHAR(10) NOT NULL UNIQUE,

manger VARCHAR(20) NOT NULL) charset=gbk;


--id 纯数字5位,非空,自增长,主键;name 10位,非空,唯一性约束,manger 自适应20位,非空


为字段添加唯一性线束:


ALTER TABLE bu5 CHANGENAME NAME CHAR(10) UNIQUE; --重新定义name字段


-------------------------------------------------------------------------------------------

0