MySQL学习笔记4:完整性约束限制字段

时间:2024-01-27 15:54:29 

完整性约束是对字段进行限制,从而符合该字段达到我们期望的效果比如字段含有默认值,不能是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)
标签:完整性,约束,限制字段
0
投稿

猜你喜欢

  • javascript禁用Tab键脚本实例

    2023-10-13 10:53:58
  • 网马解密大讲堂——网马解密中级篇(Freshow工具使用方法)

    2009-09-16 15:09:00
  • java代码获取数据库表里数据的总数操作

    2024-01-14 23:41:31
  • 原生js封装的一些jquery方法(详解)

    2024-04-19 09:47:01
  • SQL Server查看login所授予的具体权限问题

    2024-01-22 11:39:14
  • Python使用scrapy采集数据时为每个请求随机分配user-agent的方法

    2023-02-08 15:20:31
  • pycharm中选中一个单词替换所有重复单词的实现方法

    2022-11-07 02:51:16
  • SQL函数substr使用简介

    2024-01-27 11:12:02
  • PyTorch加载自己的数据集实例详解

    2022-07-29 14:10:36
  • python之PyMongo使用总结

    2023-03-11 03:17:48
  • Python zip()函数用法实例分析

    2022-10-28 21:39:53
  • 详细解读Python中的__init__()方法

    2023-03-25 17:10:27
  • 理解CSS3线性渐变

    2010-03-28 13:42:00
  • PyQt5实现拖放功能

    2023-08-06 11:52:56
  • 如何查询日期类型的数据?

    2009-11-11 20:04:00
  • python为什么会环境变量设置不成功

    2023-01-18 04:33:08
  • 利用Python编写简易的录制屏幕小工具

    2023-12-17 04:34:57
  • Python实现简单图像缩放与旋转

    2022-02-19 05:48:17
  • Python一行代码对话ChatGPT实现详解

    2022-04-24 04:07:26
  • golang 并发安全Map以及分段锁的实现方法

    2024-04-28 10:45:44
  • asp之家 网络编程 m.aspxhome.com