MySQL学习笔记4:完整性约束

MySQL学习笔记4:完整性约束

完整性约束是对字段进行限制,从而符合该字段达到我们期望的效果

比如字段含有默认值,不能是NULL等

直观点说:如果插入的数据不满足限制要求,数据库管理系统就拒绝执行操作

 

设置表的主键

主键能够标识表中每条信息的唯一性,如同身份证号码和人的关系

人可以同名,但是身份证号码却是唯一的,

创建主键的目的在于快速查找到表中的某一条信息

 

单字段主键
mysql> create table student(
    -> id int primary key,
    -> name varchar(20),
    -> sex boolean
    -> );
Query OK, 0 rows affected (0.09 sec)

创建了三个字段,其中id为主键

 

多字段主键

多字段主键由多个属性组合而成,在属性定义完之后统一设置主键

复制代码
mysql> create table student2(
    -> id int,
    -> course_id int,
    -> score float,
    -> primary key(id,course_id)
    -> );
Query OK, 0 rows affected (0.11 sec)
复制代码

student2表有三个字段,其中id和course_id的组合可以确定唯一的一条记录

 

设置表的外键

表的外键与主键是相对应的,比如表A中的id是外键,表B中的id是主键

那么就可以称表B为父表,表A为子表

设置表外键的作用在于建立与父表的联系,比如表B中id为123的学生删除后,表A中id为123的记录也随着消失

这样做的目的在于保证表的完整性

复制代码
mysql> create table student3(
    -> id int primary key,
    -> course_id int,
    -> teacher varchar(20),
    -> constraint fk foreign key(id,course_id)
    -> references student2(id,course_id)
    -> );
Query OK, 0 rows affected (0.12 sec)
复制代码

这里创建student3表,constraint后面的fk是外键别名,foreign key也就是设置外键的字段

references后的内容表示父表,和父表中的主键

需要注意的是,父表中的主键不能为空,并且主键和外键的数据类型要一致

 

设置表的非空约束

非空性很好理解,就是设置表中字段的值不能为空(NULL)

如果在已经设置此约束性条件的字段中插入空值,数据库系统则会报错

mysql> create table student4(
    -> id int not null,
    -> name varchar(20),
    -> sex boolean
    -> );
Query OK, 0 rows affected (0.10 sec)

这里的not null就是约束条件

 

设置表的唯一性约束

唯一性是指表中该字段的值不能重复出现,设置表的唯一性约束

也就是给表中某个字段加上unique

mysql> create table student5(
    -> id int unique,
    -> name varchar(20)
    -> );
Query OK, 0 rows affected (0.10 sec)

此处id字段便不可重复

 

设置表的属性值自动增加

auto_increment主要用于为表中插入的新记录自动生成唯一的ID

一个表只能有一个字段使用auto_increment约束

并且该字段必须为主键的一部分

mysql> create table student6(
    -> id int primary key auto_increment,
    -> name varchar(20)
    -> );
Query OK, 0 rows affected (0.12 sec)

这里的id是主键,并且会自动增加id值,比如1,2,3,4……

需要注意的是,auto_increment约束的值必须是整数类型

 

设置表中属性的默认值

在表中插入一条新的记录时,如果没有为该字段赋值

那么数据库系统会自动为该字段赋上一条默认值

mysql> create table student7(
    -> id int primary key,
    -> score int default 0
    -> );
Query OK, 0 rows affected (0.10 sec)

此处的score字段便会默认为0

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值