MySQL数据库 12:约束

news/2024/7/7 21:26:10

约束:

在MySQL中,约束是一种限制数据表中列值的规定。保证数据库中的数据正确,有效性和完整性。MySQL中的约束有以下几种:

1. 主键约束(Primary Key Constraint):主键是用于唯一标识表中每行记录的列。主键约束要求每个主键列的值都是唯一的,且不能为NULL。一个表只能有一个主键。

2. 唯一约束(Unique Constraint)唯一约束要求列中的值各不相同,且可以为空(NULL)。一个表可以有多个唯一约束。

3. 非空约束(Not Null Constraint):非空约束要求列中的值不能为NULL

4. 外键约束(Foreign Key Constraint):外键是用于关联两个表的列。外键约束要求参照表中必须存在与被参照表中主键列相符的值。MySQL中的外键约束需要引用参照表中的主键列,从而保证参照表中的值是唯一的。

5.默认约束(Default constraint):保存数据的时候,如果未指定该字段的值,就采用默认值。

6.检查约束(Check constraints):保证字段值满足某一个条件

这些约束可用于对表中数据进行更全面、更安全的控制。例如,主键可以确保每个表行的唯一标识,唯一约束可以保证表中没有重复数据,非空约束可以避免NULL值,外键约束可以确保数据表之间的数据完整性。


 

约束时作用在字段上的,它可以限制字段的数据。在创建表或修改表的时候添加约束,一个字段我们可以添加多个约束。


案例:创建以下表:

 代码:

create table user (
    id int primary key  auto_increment comment '年龄' ,
    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'用户表';

 运行结果:

 我们通过插入数据来一个个验证约束的功能

1.id的主键约束:

insert into user(name, age, status,gender) values('tom',19,'1','男'),('koy',14,'1','女');

结果:

 我们发现即使不给id插值,他也会按照我们设定好的递增进行,也就是永远不会出现id重复的情况,而不会重复的id就作为每条数据的唯一标识。

在这里需要注意错误的数据虽然会因为约束而不能存储到表中,但是他也会有自己的主键,只是我们无法在这张表中调用,因此如果我们如果表中已经有两条数据,我们再输入不符合约束的两条数据,第五次输入一条符合约束的数据,那么此时这条符合约束的数据的id应该是5,而不是3,因为前面那两条没有输入成功的数据也为自己获取了一个唯一的主键,我们可以看下面status的默认约束来验证这条结论。

2.name的非空约束:

insert into user(name, age, status,gender) value(null,17,'1','男');

结果:

由于非空约束这里会直接报错,但是要注意的是空字符不是空,这里的非空约束是指值不能为NULL;
 

 name的唯一约束:

insert into user(name, age, status,gender) value('koy',10,'1','女');

结果:前面已经有koy这个名字了,受到唯一约束的影响,此时如果我们名字重复,会直接报错。

 3.age的检查约束:

insert into user(name, age, status,gender) value('kot',130,'1','女');

结果:我们在前面定义的时候,约定了age的年龄范围在1-119之间,因此输入age=130会报错

 4.status的默认约束:

默认约束采取有输入采取输入值,没输入采取默认值的做法。 

insert into user(name, age,gender) value('kob',15,'女');

结果:
 

 5.外键约束:

添加外键:


在这里我们预先建立一张表:

 而他和我们之前那张表的关系为:

 这两张表之间的关系为我们的status需要通过第二张表来补全。我们把具有外键status的表称为是子表,具有外键指向的主键的表我们称为是父表。但是目前来讲,这两张表只在逻辑上有关系,但是在数据库层面并没有建立起任何关系,如果我们删除dept表中的1,user中status列中的1仍然存在,这个时候就需要给user中的status加上外键约束

创建外键的语法:

CREATE TABLE 表名(
    字段名 数据类型,
    .....
    [CONSTRAINT][外键名称]FOREIGN KEY(外键字段名) REFERENCES 主表 (主表列名)
);

ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 主表 (主表列名);

案例:我t们为user中的status添加外键约束,使其与dept表相连。

alter table user add constraint fk_user_dept_id foreign key (status) references dept(id) ;

执行成功以后我们会发现status上方多出来一个蓝色的钥匙 ,就说明它已经是一个外键了

 此时我们尝试在dept中删除id为1.

 就会报错,因为此时user表中还有关于这个id的信息,因此我们的父表不可以对这个数据进行删除,我们也就在两个表之间建立了关联。

外键的删除:

ALTER TABLE 表名 DROP FORGEIGN KEY 外键名称

外键约束:

 语法:

alter table 表名 add constraint 外键名称 foreign key (外键字段) references 主表名(主表字段名) ON UPDATE CASCADE ON DELETE CASCADE ;

结束!
 


http://lihuaxi.xjx100.cn/news/1215993.html

相关文章

Day_44希尔排序

目录 一. 关于希尔排序 二. 希尔排序的实现过程 三. 希尔排序的代码实现 1. 核心代码 2. 修改后的代码 四. 代码展示 五. 数据测试 六. 总结与反思 一. 关于希尔排序 希尔排序按其设计者希尔&#xff08;Donald Shell&#xff09;的名字命名&#xff0c;该算法由希尔在 19…

《.NET 下最快比较两个文件内容是否相同》之我的看法验证

我对文件对比这一块还是比较感兴趣的&#xff0c;也想知道哪种方式性价比最高&#xff0c;效率最好&#xff0c;所以&#xff0c;根据这篇文章&#xff0c;我自己也自测一下&#xff0c;顺便留出自己对比的结果&#xff0c;供大佬们参考一二。 大致对比方案 我这边根据文章里…

[chatGPT攻略] 如何检测文本内容是否由ChatGPT生成 ?

[chatGPT攻略] 如何检测文本内容是否由ChatGPT生成 ? 在 ChatGPT 爆火的两个月内&#xff0c;学生就已经自发用这种工具做作业、写论文偷懒&#xff0c;编剧会用它编故事试试出乎人意料的故事走向&#xff0c;文案编辑用它来给自己打工。 在用工具给自己省事这件事上&#xf…

VMware虚拟机Ubuntu磁盘空间扩充详细教程

文章目录 一、写在前面二、具体步骤三、最后总结 一、写在前面 最近在做Linux内核相关实验的时候&#xff0c;发现有时候我们编译出来的内核太大&#xff0c;如果VMware虚拟机空间分配不足会导致编译Linux内核失败&#xff0c;经过摸索&#xff0c;发现可以扩充Ubuntu的磁盘空间…

【链表的分类】

链表是一种常用的数据结构&#xff0c;它由一系列节点组成&#xff0c;每个节点包含一个数据元素和指向下一个节点的指针。根据节点的连接方式和节点的性质&#xff0c;链表可以分为多种类型。 单向链表&#xff08;Singly Linked List&#xff09; 单向链表是最基本的链表类…

【Java】深入理解Java虚拟机 | 垃圾收集器GC

《深入理解Java虚拟机》的阅读笔记——第三章 垃圾收集器与内存分配策略。 参考了JavaGuide网站的相关内容&#xff1a;https://javaguide.cn/ Q&#xff1a;哪些内存需要回收&#xff1f;什么时候回收&#xff1f;如何回收&#xff1f; 2 对象已死吗&#xff1f; 2.1 引用…

java设计模式(十二)代理模式

目录 定义模式结构角色职责代码实现静态代理动态代理jdk动态代理cglib代理 适用场景优缺点 定义 代理模式给某一个对象提供一个代理对象&#xff0c;并由代理对象控制对原对象的引用。说简单点&#xff0c;代理模式就是设置一个中间代理来控制访问原目标对象&#xff0c;以达到…

javascript基础二十九:JavaScript如何判断一个元素是否在可视区域中?

一、用途 可视区域即我们浏览网页的设备肉眼可见的区域&#xff0c;如下图 在日常开发中&#xff0c;我们经常需要判断目标元素是否在视窗之内或者和视窗的距离小于一个值&#xff08;例如 100 px&#xff09;&#xff0c;从而实现一些常用的功能&#xff0c;例如&#xff1a;…