default
创建表时使用default约束条件可以设置默认值;
下面创建表t1,默认gender值为male
create table t1(id int, name varchar(16),gender enum('male','female') default 'male');
# 插入数据
insert into t2(id,name) values(1,'zhou'); # gender默认为male
insert into t2(id,name,gender) values(2,'zhou','female'); # gender设置为female
unique
unique设置值唯一
create table t3(id int unique,name varchar(16)); # 设置id唯一
即插入重复的id会报错
联合唯一
比如ip和port 单个都可以重复 但是联合起来加载必须唯一
create table t4(id int,ip varchar(16),port int,unique(ip,port));
primary key
primary key的实际效果相当于not null+unique,即非空且唯一
create table t5(id int primary key,name varchar(16));
insert into t5(id,name) values(null,'zhou')); # 报错
insert into t5(id,name) values(1,'zhou'),(1,'q')); # 报错
auto_incremenrt自增
如:设置id自增
create table t6(id int primary key auto_increment,name varchar(16));
insert into t6(name) values ('zhou'),('jason'),('egon');
注意
在把表数据删除之后自增不会解除
即删除t6表的数据后,再往t6插入新的数据,id是从4开始的
可以用 truncate t6
清空表数据并重置主键