MySQL六种约束的示例详解
作者:绿仔牛奶_ 发布时间:2024-01-16 19:15:38
标签:MySQL,约束
什么是约束
作用于表上的规则,限制存储在表中的数据
约束分类:
约束 | 描述 | 关键字 |
---|---|---|
非空约束 | 该字段数据不能为null | NOT NULL |
唯一约束 | 该字段数据唯一不重复 | UNIQUE |
主键约束 | 一行数据的唯一标识(非空且唯一) | PRIMARY KEY |
默认约束 | 未指定该字段值则使用默认值 | DEFAULT |
检查约束(8.0.16以后) | 该字段值满足某一条件 | CHECK |
外键约束 | 为两张表建立连接(数据一致、完整) | FOREIGN KEY |
创建表示例:
CREATE TABLE info(
`id` INT UNIQUE auto_increment PRIMARY KEY COMMENT'ID唯一标识',
`name` VARCHAR(10) NOT NULL UNIQUE COMMENT'姓名',
`age` INT CHECK(age > 0 && age < 120) COMMENT '年龄',
`status` CHAR(1) DEFAULT'1' COMMENT'状态',
`gender` CHAR(1) COMMENT'性别'
)COMMENT '用户信息表';
外键约束
外键通常用来为两张表建立连接,两张利用外键连接的表被称为父子表。
子表当中会设定一个外键字段用于关联父表的主键字段
即拥有外键的表是子表(从表),该外键对应另一个表的主键这个表称之为父表
如果没有设置外键,仅仅是将子表开了一个字段对应上了父表的主键字段在mysql层面是依旧没有任何关系的。此时两个表仅存在逻辑关系,无法保证数据的完整性和一致性
创建外键语法:
-- 在创建表时创建
CREATE TABLE son(
...
CONSTRAINT [外键名称] FOREIGN KEY(外键字段名) REFERENCES 主表名(主表主键字段名)
);
-- 创建表后为表添加主键
ALTER TABLE 表名ADD CONSTRAINT 外键名称 FOREIGN KEY(外键字段名) REFERENCES 主表(主表主键字段名)
-- 删除外键
alter table 表名 drop foreign key 外键名称;
创建示例:
# 父表
CREATE TABLE father(
`id` INT auto_increment PRIMARY KEY COMMENT'父表ID',
`name` VARCHAR(20) NOT NULL COMMENT'姓名',
`password` VARCHAR(20) DEFAULT(0000)
);
INSERT INTO father VALUES(null,'小三','1234'),(null,'小四','1234'),(null,'小五','1234'),(null,'小六','1234');
# 子表
CREATE TABLE son(
`id` INT auto_increment PRIMARY KEY COMMENT'子表ID',
`status` varchar(10) COMMENT '状态',
`fa_id` INT COMMENT'外键',
CONSTRAINT fk_father_son FOREIGN KEY(fa_id) REFERENCES father(id)
);
INSERT INTO son VALUES(null,'活',2),(null,'活',3),(null,'死',3),(null,'活',2);
上述示例 子表设置了外键,字段名为fa_id并关联到了父表主键id,外键名称为fk_father_son
创建完成后,我们添加几组数据。将几个son添加到表中,并设置外键字段属性为某个father。比如(null,‘活’,3),那么此时如果我们尝试去删除父表id=3的这一行数据,就会提示错误。因为两个表已经在mysql层面上进行了关联
总结:
从表的外键通常是主表的主键
从表中外键的类型必须与主表中的主键类型一致
主表数据发生变化时应注意从表数据的一致性问题
来源:https://blog.csdn.net/yuqu1028/article/details/128875020
0
投稿
猜你喜欢
- 在IE浏览器调试代码,我们可以选择使用 IE WebDeveloper但是我个人用惯了ff浏览器下的firebug,所以在网上搜了一下,如果
- 如何制作一个WAP手机的WML网页?代码如下:<%@Language=VBScriptMaxNoAds = 10'
- 一直以来,JS前端代码因为必须经过IE明文解析,某些加密的JS如:JScript.Encode也因为树大招风,早就被人破解了。还有些加密的手
- Python是支持可视化编程,即编写gui程序,你可以用它来编写自己喜欢的桌面程序。使用wxPython来做界面非常的简单,只是不能像C#一
- 问题今天用nohup后台执行python程序,并将标准输出和错误输出重定向到一个log文件,但发现log文件隔好久才会更新,很煎熬。。。然而
- 如下所示:#随机数的使用import random #导入randomrandom.randint(0,9)#制定随机数0到9i=rando
- 首先,我们用webpy写一个简单的网站,监听8080端口,返回“Hello, EverET.org”的页面。然后我们使用我们的forward
- 1.算法:设有一组关键字{ K 1 , K 2 ,…, K n };排序开始就认为 K 1 是一个有序序列;让 K 2 插入上述表长为 1
- 大概在九九年做游戏网站的时候,就对文章的发布感到麻烦,不过那会儿玩ASP不精。只是将就用着。在遇到长文件 10000 字时网页就是一大片长了
- 前言在设计用例的时候,有些用例只是参数数据的输入不一样,比如登录这个功能,操作过程是一样的.如果重复去写操作过程会增加代码量,对应这种多组数
- vscode 的调试功能其实提供了一键编译运行的功能(ctrl+F5),但是启动特别特别慢… 又不想安装插件,后来发现vscode 提供了一
- 开篇先明义:lambda是表达式,而def函数是语句代码块所以lambda其实就是一个稍微高级一点的式子而已,只不过这个式子比较长,而且还会
- 编写一个prod()函数,可以接受一个list并利用reduce()求积。from functools import reducedef p
- 在这系列视觉设计的文章间隙插一篇字体单位的文章。前文说了,字体单位应该用em而不用px,原因简单来说就是支持IE6下的字体缩放,在页面中按c
- 前言Django 和 DRF(django rest framawork) 的结合在 python 后台中经常出现的组合。对于异常的全局处理
- 如果你有一字段dm记录了一个url,为了更好的优化模糊查询速度或统计速度,在数据表原有的结构上增加3个字段,分别为 `sdm`
- 单向链表单向链表也叫单链表,是链表中最简单的一种形式,它的每个节点包含两个域,一个信息域(元素域)和一个链接域。这个链接指向链表中的下一个节
- 前言Iframe 是一种将网页嵌入到另一个页面的内容中的方法。这是通过使用 HTML 元素、外部网站的 URL 以及窗口在您的网站上的外观参
- 本文实例分析了ThinkPHP中的__initialize()和类的构造函数__construct()。分享给大家供大家参考。具体分析如下:
- 什么是Three.js? 如果你正在读这篇文章,你可能对Three.js有一定的了解,那我们来简单地介绍下Three.js是什么.Three