主键约束!

目录

主键约束(primary key,简称PK)非常重要五颗星*****

1. 主键约束的相关术语?

2. 什么是主键?有啥用?

3. 主键的特征

4. 怎么给一张表添加主键约束呢?

4.1 单一主键:1个字段做主键

4.2 使用表级约束添加主键

4.3 复合主键:多个字段联合起来做主键

5. 一张表中主键约束只能添加1个(主键只能有1个。)

6. 主键值 

7. 主键除了单一主键和复合主键之外,还可以这样进行分类?

7.1 在实际开发中使用业务主键多,还是使用自然主键多一些?

7.2 在mysql当中,有一种机制,可以帮助我们自动维护一个主键值


主键约束(primary key,简称PK)非常重要五颗星*****

1. 主键约束的相关术语?

  • 主键约束:就是一种约束。
  • 主键字段:该字段上添加了主键约束,这样的字段叫做主键字段
  • 主键值:主键字段中的每一个值都叫做主键值。

2. 什么是主键?有啥用?

  • 主键值是每一行记录的唯一标识。
  • 主键值是每一行记录的身份证号!!!

记住:任何一张表都应该有主键,没有主键,表无效!!

3. 主键的特征

not null + unique(主键值不能是NULL,同时也不能重复!)

4. 怎么给一张表添加主键约束呢?

4.1 单一主键:1个字段做主键

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

4.2 使用表级约束添加主键

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 不能重复

4.3 复合主键:多个字段联合起来做主键

表级约束主要是给多个字段联合起来添加约束

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不能同时重复

在实际开发中不建议使用复合主键,建议使用单一主键!因为主键值存在的意义就是这行记录的身份证号,只要意义达到即可,单一主键可以做到。复合主键比较复杂,不建议使用!!!

5. 一张表中主键约束只能添加1个(主键只能有1个。)

drop table if exists t_vip;
create table t_vip(
         id int primary key,
         name varchar(255) primary key
);

6. 主键值 

  • 建议使用:int、bigint、char 等类型。
  • 不建议使用:varchar来做主键。主键值一般都是数字,一般都是定长的!

7. 主键除了单一主键和复合主键之外,还可以这样进行分类?

  • 自然主键:主键值是一个自然数,和业务没关系。
  • 业务主键:主键值和业务紧密关联,例如拿银行卡账号做主键值,这就是业务主键!

7.1 在实际开发中使用业务主键多,还是使用自然主键多一些?

  • 自然主键使用比较多,因为主键只要做到不重复就行,不需要有意义。
  • 业务主键不好,因为主键一旦和业务挂钩,那么当业务发生变动的时候,可能会影响到主键值,所以业务主键不建议使用,尽量使用自然主键。

7.2 在mysql当中,有一种机制,可以帮助我们自动维护一个主键值

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;

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值