MySQL(3)—— 约束

本文主要讨论数据库中的约束。

约束是关系数据库的一个重要功能;数据库中的约束是表中数据的限制条件,用于保证数据的完整性和一致性。

约束类型

  • NOT NULL:指示某列不能存储NULL值
  • UNIQUE:保证某列的每行必须有唯一的值
  • DEFAULT:规定没有给列赋值时的默认值
  • PRIMARY KEY:确保某列有唯一标识,有助于更容易更快速地找到表中的一个特定的记录
  • FOREIGN KEY:保证一个表中的数据匹配另一个表中的值的参照完整性
  • CHECK:保证列中的值符合指定的条件。

NOT NULL

在前面建表的时候,我们可以看到表的属性中有NULL这一个字段;当没有指定非空约束时,当前的列是可以写入一个NULL值的;如果要把某一列定义为一个必填项,就可以使用NOT NULL约束。比如:

如果要使用该约束,需要在创建表时进行设定:

sql 复制代码
create table student (
    id bigint not null,
    name varchar(50)
);

查看一下student表:

所以此处在输入数据时,id字段不能输入NULL值,MySQL会做一次非空校验。


UNIQUE

保证某列的每行必须有唯一的值,意思就是该列的值在整个表中不能重复。

创建一个在id字段进行唯一约束的表。


DEFAULT

表示在输入数据时默认插入的数据;不规定时默认为空。可以通过Default来规定写入时的默认值。这里就不做演示。


PRIMARY KEY

表示++主键约束++。主键约束既是非空的也是唯一的。把表中的某一列设置为非空且唯一,那么该字段就是该表的主键。

【主键】一张表的每行数据都需要至少一个不能重复、不能为空的标识;该标识对应的字段就是主键。一张表只能有一个主键。一个表中不允许出现两个主键,但可以同时包含多个列(复合主键)

一般在每个表建立时使用如上命名来设定主键。其中auto_increment表示自增。该命令可以让数据库帮我们去维护主键的增长,不用我们自己去运算;在插入的时候先找到最大值,然后在该值的基础上加1,生成一个新的值来作为新数据行的主键的值。

而也有复合主键的情况,即以两列的数据来判断非空和唯一,写法如下:


FOREIGN KEY

类似于上面的主键,foreign key用于设置外键

【外键】在一张表中引入另一张表的主键,这个引入的主键就是外键。

外键的存在可以建立两张表之间的联系。外键的书写如下:

sql 复制代码
foreign key (字段名)references 主表(列)

CHECK

直接用一个例子理解:

该代码用于在插入数据时确保 gender 字段输入的是 "男"或者"女";

可以看到,当输入其他数据时会报错,并且不会存入数据库中。

相关推荐
dapeng28702 小时前
用Python破解简单的替换密码
jvm·数据库·python
setmoon2142 小时前
Python数据库操作:SQLAlchemy ORM指南
jvm·数据库·python
sqyno1sky2 小时前
高级爬虫技巧:处理JavaScript渲染(Selenium)
jvm·数据库·python
学编程就要猛2 小时前
MySQL:库操作
数据库·mysql
短剑重铸之日2 小时前
《ShardingSphere解读》12 解析引擎:SQL 解析流程应该包括哪些核心阶段?(下)
数据库·后端·sql·架构·shardingsphere·分库分表
2401_884563242 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
2401_891482172 小时前
使用Plotly创建交互式图表
jvm·数据库·python
dapeng28702 小时前
开发一个简单的Python计算器
jvm·数据库·python
轩情吖2 小时前
MySQL Connect(2)
android·mysql·adb·workbench·mysql连接池·图形化mysql