目录
主键约束(primary key,简称PK)非常重要五颗星*****
7.1 在实际开发中使用业务主键多,还是使用自然主键多一些?
7.2 在mysql当中,有一种机制,可以帮助我们自动维护一个主键值
记住:任何一张表都应该有主键,没有主键,表无效!!
not null + unique(主键值不能是NULL,同时也不能重复!)
drop table if exists t_vip;
create table t_vip(
id int primary key, // 列级约束
name varchar(255)
);
insert into t_vip(id,name) values(1,'zhangsan');
insert into t_vip(id,name) values(2,'lisi');
select * from t_vip;
insert into t_vip(id,name) values(2,'wangwu');
错误:id 不能重复
insert into t_vip(name) values('zhaoliu');
错误:id 不能为NULL
drop table if exists t_vip;
create table t_vip(
id int,
name varchar(255),
primary key(id) // 表级约束
);
insert into t_vip(id,name) values(1,'zhangsan');
insert into t_vip(id,name) values(1,'lisi');
错误:id 不能重复
表级约束主要是给多个字段联合起来添加约束
drop table if exists t_vip;
create table t_vip(
id int,
name varchar(255),
email varchar(255),
primary key(id,name)
);
insert into t_vip(id,name,email) values(1,'zhangsan','zhangsan@123.com');
insert into t_vip(id,name,email) values(1,'lisi','lisi@123.com');
select * from t_vip;
insert into t_vip(id,name,email) values(1,'lisi','lisi@123456.com');
错误:id和name不能同时重复
在实际开发中不建议使用复合主键,建议使用单一主键!因为主键值存在的意义就是这行记录的身份证号,只要意义达到即可,单一主键可以做到。复合主键比较复杂,不建议使用!!!
drop table if exists t_vip;
create table t_vip(
id int primary key,
name varchar(255) primary key
);
auto_increment:表示自增,从1开始,以1递增!
drop table if exists t_vip;
create table t_vip(
id int primary key auto_increment,
name varchar(255)
);
insert into t_vip(name) values('zhangsan');
insert into t_vip(name) values('zhangsan');
insert into t_vip(name) values('zhangsan');
insert into t_vip(name) values('zhangsan');
insert into t_vip(name) values('zhangsan');
insert into t_vip(name) values('zhangsan');
insert into t_vip(name) values('zhangsan');
insert into t_vip(name) values('zhangsan');
select * from t_vip;