>  기사  >  데이터 베이스  >  MySQL의 6가지 일반적인 제약 조건 유형에 대한 심층 분석

MySQL의 6가지 일반적인 제약 조건 유형에 대한 심층 분석

青灯夜游
青灯夜游앞으로
2021-09-16 19:55:033117검색

MySQL의 6가지 일반적인 제약 조건 유형에 대한 심층 분석

제약조건의 문자 그대로의 의미는 작업을 수행하는 방법을 규정하거나 제한하는 것입니다. MySQL에서 제약조건은 데이터 테이블의 데이터에 대한 규칙을 지정하는 것입니다. 즉, 신뢰성을 보장하기 위해 데이터를 제한하는 것입니다. 실제로 특정 열에는 Null 값이 나타날 수 있습니다. 실제로 다음과 같은 유형의 제약 조건이 발생합니다.

  • NOT NULL: 열이 NULL 값을 가질 수 없는지 확인
  • NOT NULL : 确保列不能有NULL值
  • CHECK : 确保列中的值满足特定条件
  • UNIQUE : 确保一列中的所有值都不同
  • PRIMARY KEYNOT NULLUNIQUE组合,唯一标识表中的每一行
  • FOREIGN KEY : 外键约束
  • DEFAULT : 如果未指定值,则为列设置默认值

【相关推荐:mysql视频教程

约束

1.NULL

MySQL中通过使用NOT NULL确保列中不会出现Null值,创建表时候格式如下:

mysql> create table user(name varchar(255)not null);
Query OK, 0 rows affected (0.06 sec)

如果试图插入一个null值,则会抛出异常。

mysql> insert user values(null);
ERROR 1048 (23000): Column 'name' cannot be null

或者在现有表上新增NOT NULL约束。

mysql> alter table user modify name varchar(255) not null;
Query OK, 0 rows affected (0.07 sec)
Records: 0  Duplicates: 0  Warnings: 0

删除NOT NULL约束。

mysql> alter table user modify name varchar(255)  null;
Query OK, 0 rows affected (0.09 sec)
Records: 0  Duplicates: 0  Warnings: 0

2.CHECK

如果想在列上定义条件约束,可以使用CHECK,比如下面,强制让年龄字段大于18,小于80,否则将会报错。

mysql> create table user(age int(11) check(age>18 and age <80));
Query OK, 0 rows affected, 1 warning (0.06 sec)

插入测试,可以发现9、81在插入的时候抛出异常。

mysql> insert user values(9);
ERROR 3819 (HY000): Check constraint &#39;user_chk_1&#39; is violated.

mysql> insert user values(19);
Query OK, 1 row affected (0.01 sec)

mysql> insert user values(81);
ERROR 3819 (HY000): Check constraint &#39;user_chk_1&#39; is violated.
mysql>

也可以进行多列约束,如年龄必须大于18,城市必须为中国。

mysql> create table user(age int(11),city varchar(255) ,check(age>18 and city=&#39;中国&#39;));
Query OK, 0 rows affected, 1 warning (0.05 sec)

插入测试。

mysql> insert user values(81,&#39;2&#39;);
ERROR 3819 (HY000): Check constraint &#39;user_chk_1&#39; is violated.
mysql> insert user values(8,&#39;2&#39;);
ERROR 3819 (HY000): Check constraint &#39;user_chk_1&#39; is violated.
mysql> insert user values(20,&#39;2&#39;);
ERROR 3819 (HY000): Check constraint &#39;user_chk_1&#39; is violated.
mysql> insert user values(20,&#39;中国&#39;);
Query OK, 1 row affected (0.01 sec)

mysql> insert user values(20,&#39;中国1&#39;);
ERROR 3819 (HY000): Check constraint &#39;user_chk_1&#39; is violated.
mysql> insert user values(85,&#39;中国&#39;);
Query OK, 1 row affected (0.01 sec)

mysql> insert user values(9,&#39;中国&#39;);
ERROR 3819 (HY000): Check constraint &#39;user_chk_1&#39; is violated.

还可以让列值必须在指定集合中,如性别必须在男、女、未知、人妖集合中。

mysql> create table user(sex varchar(255) check (sex in (&#39;男&#39;,&#39;女&#39;,&#39;未知&#39;,&#39;人妖&#39;)));
Query OK, 0 rows affected (0.05 sec)

插入测试。

mysql> insert user values("男");
Query OK, 1 row affected (0.02 sec)

mysql> insert user values("男男");
ERROR 3819 (HY000): Check constraint &#39;user_chk_1&#39; is violated.
mysql> insert user values("女");
Query OK, 1 row affected (0.01 sec)

mysql> insert user values("人妖");
Query OK, 1 row affected (0.00 sec)

为约束命名并删除约束。

mysql> create table user (age int(11) ,constraint CHK_AGE check(age>18));
Query OK, 0 rows affected, 1 warning (0.05 sec)

mysql> insert user values(5);
ERROR 3819 (HY000): Check constraint &#39;CHK_AGE&#39; is violated.

mysql> alter table user drop check CHK_AGE;
Query OK, 0 rows affected (0.03 sec)
Records: 0  Duplicates: 0  Warnings: 0mysql> insert user values(5);
Query OK, 1 row affected (0.01 sec)

但是,这样的写法你见过吗?

猜猜下面的作用是什么。

这其实是一个case when条件判断,让其仅仅可以插入>=18,或者是在0-10之间的数。

CREATE TABLE `user` (`age` int(11) CHECK 
(((case when (`age` >=18) then 1 
else 
(case when age<10 and age >0 then 1 else 2 end) end) =1)));

3.UNIQUE

UNIQUE约束确保列中的没有重复的值,UNIQUE和 PRIMARY KEY约束都为一列值的唯一性提供保障,但是UNIQUE每个表可以出现多次,而PRIMARY KEY只能出现一个。

如下面name字段不能重复。

mysql> create table user (name varchar(255),unique(name));
Query OK, 0 rows affected (0.07 sec)

插入测试。

mysql> insert user values("张三");
Query OK, 1 row affected (0.02 sec)

mysql> insert user values("张三");
ERROR 1062 (23000): Duplicate entry &#39;张三&#39; for key &#39;user.name&#39;mysql>

对此约束进行起名,并删除。

mysql> create table user (name varchar(255),constraint name_un unique(name));
Query OK, 0 rows affected (0.07 sec)

mysql> insert user values("张三");
Query OK, 1 row affected (0.02 sec)

mysql> insert user values("张三");
ERROR 1062 (23000): Duplicate entry &#39;张三&#39; for key &#39;user.name_un&#39;
mysql> alter table user drop index name_un;
Query OK, 0 rows affected (0.03 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> insert user values("张三");
Query OK, 1 row affected (0.02 sec)

插入后可以用以下语句查看创建语句。

mysql> show create table user;
+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table                                                                                                                                                 |
+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------+
| user  | CREATE TABLE `user` (
  `name` varchar(255) DEFAULT NULL,
  UNIQUE KEY `name_un` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci |
+-------+--------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

要删除UNIQUE约束,可以使用DROP INDEXALTER TABLE语句:

mysql> DROP INDEX name_un ON user;
Query OK, 0 rows affected (0.03 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> show create table user;
+-------+-----------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table                                                                                                                |
+-------+-----------------------------------------------------------------------------------------------------------------------------+
| user  | CREATE TABLE `user` (
  `name` varchar(255) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci |
+-------+-----------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

在现有表上添加。

mysql> alter table user add constraint name_un unique(name);
Query OK, 0 rows affected (0.04 sec)
Records: 0  Duplicates: 0  Warnings: 0

4.PRIMARY KEY

通常每个表中包含一个用于唯一标识每一行的值,这个列就被称为PRIMARY KEY。

mysql> create table user (id int(11) ,age int(11),primary key (id));
Query OK, 0 rows affected, 2 warnings (0.06 sec)

mysql> insert user values(1,2);
Query OK, 1 row affected (0.02 sec)

mysql> insert user values(1,2);
ERROR 1062 (23000): Duplicate entry &#39;1&#39; for key &#39;user.PRIMARY&#39;mysql>

5.FOREIGN KEY

FOREIGN KEY用于约束表中的一个字段必须是另一个表中某个字段所存在的值,但是在另一个表中,这个列不一定是主键,但必须是唯一性索引,否则会创建失败。

比如orders表中的userId必须参考user表中的id,如果插入的userId在user表中不存在,则无法插入。

mysql> create table orders (id int(11) primary key ,userId int(11) ,  FOREIGN KEY (userId) REFERENCES user(id) );
Query OK, 0 rows affected, 2 warnings (0.06 sec)

mysql> insert orders values(1,3);
ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint fails (`t`.`orders`, CONSTRAINT `orders_ibfk_1` FOREIGN KEY (`userId`) REFERENCES `user` (`id`))

mysql> insert orders values(1,1);
Query OK, 1 row affected (0.01 sec)

但是存在一个问题,如果主表(user)中记录被删除或者更新,那orders中的记录该怎么办?,如下面的例子,可以发现直接报错了。

mysql> update user set id =2 where id =1;

Cannot delete or update a parent row: a foreign key constraint fails (`t`.`orders`, CONSTRAINT `orders_ibfk_1` FOREIGN KEY (`userId`) REFERENCES `user` (`id`)

MySQL提供了几个约束可以帮助我们解决这类问题,比如在user表更新时,orders也相继更新。

  1. RESTRICT:如果子表中有记录,则拒绝更新或删除父表中的记录。

  2. CASCADE:更新或删除父表中的记录时,自动更新或删除子表中的记录。

  3. SET NULL:在更新或删除父表记录时,将子表中字段的值设置为空。

可以发现,默认采用的是RESTRICT,下面来修改一下,让在更新时候也同样更新,在删除时候设置null。

mysql> alter table orders add constraint orders_ibfk_1  FOREIGN KEY (`userId`) REFERENCES `user` (`id`) on update cascade on
delete set null;
Query OK, 0 rows affected (0.12 sec)
Records: 0  Duplicates: 0  Warnings: 0

测试更新

mysql> select * from user;
+----+--------+
| id | name   |
+----+--------+
|  1 | 张三   |
+----+--------+
1 row in set (0.00 sec)

mysql> select * from orders;
Empty set (0.00 sec)

mysql> insert orders values (1,1);
Query OK, 1 row affected (0.01 sec)

mysql> update user set id =2 where id =1;
Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from orders;
+----+--------+
| id | userId |
+----+--------+
|  1 |      2 |
+----+--------+
1 row in set (0.01 sec)

测试删除。

mysql> delete from user where id =2;
Query OK, 1 row affected (0.02 sec)

mysql> select * from orders;
+----+--------+
| id | userId |
+----+--------+
|  1 |   NULL |
+----+--------+
1 row in set (0.00 sec)

6.DEFAULT

DEFAULTCHECK: 열의 값이 특정 조건을 충족하는지 확인

UNIQUE : 열의 모든 값이 다른지 확인
PRIMARY KEY: NOT NULL의 조합 UNIQUE, 고유 식별자 테이블의 각 행

FOREIGN KEY: 외래 키 제약 조건

DEFAULT: 값이 지정되지 않은 경우 , 열의 기본값 설정 li>

【관련 권장사항: mysql 비디오 튜토리얼

제약조건

1.NULL Strong>

MySQL에서는 NOT NULL을 사용하여 Null 값이 열에 나타나지 않도록 하세요. 테이블을 생성할 때 형식은 다음과 같습니다.

mysql> create table user(age int(11) default 18);
Query OK, 0 rows affected, 1 warning (0.05 sec)

mysql> insert user values();
Query OK, 1 row affected (0.02 sec)

mysql> select * from user;
+------+
| age  |
+------+
|   18 |
+------+
1 row in set (0.00 sec)
시도해 보세요. null 값을 삽입하려면 예외가 발생합니다.

rrreee🎜또는 기존 테이블에 새로운 NOT NULL 제약 조건을 추가하세요. 🎜rrreee🎜 NOT NULL 제약 조건을 제거하세요. 🎜rrreee

2.CHECK

🎜열에 조건부 제약 조건을 정의하려면 다음과 같이 CHECK를 사용하면 됩니다. 연령 필드를 18보다 크고 80보다 작게 설정하려면 오류가 보고됩니다. 🎜rrreee🎜삽입 테스트에서 삽입 시 9와 81에서 예외가 발생하는 것을 확인할 수 있습니다. 🎜rrreee🎜나이는 18세 이상이어야 하고 도시는 중국이어야 하는 등 다중 열 제약 조건을 수행할 수도 있습니다. 🎜rrreee🎜삽입 테스트. 🎜rrreee🎜 성별이 남성, 여성, 알 수 없음, 여성 세트에 있어야 하는 것처럼 열 값이 지정된 세트에 있어야 한다고 지정할 수도 있습니다. 🎜rrreee🎜삽입 테스트. 🎜rrreee🎜제약조건 이름을 지정하고 제약조건을 삭제하세요. 🎜rrreee🎜그런데 이런 글 본 적 있나요? 🎜🎜아래 기능이 무엇인지 맞춰보세요. 🎜🎜실제로는 18보다 크거나 0~10 사이의 숫자만 삽입할 수 있는 조건부 판단의 경우입니다. 🎜rrreee

3.UNIQUE

🎜UNIQUE 제약 조건은 열에 중복된 값이 없도록 보장합니다. , UNIQUEPRIMARY KEY 제약 조건은 모두 열 값의 고유성을 보장하지만 UNIQUE는 각 테이블에 여러 번 나타날 수 있습니다. code>PRIMARY KEY는 하나만 나타날 수 있습니다. 🎜🎜예를 들어 아래 이름 필드는 중복될 수 없습니다. 🎜rrreee🎜삽입 테스트. 🎜rrreee🎜이 제약 조건의 이름을 지정하고 삭제하세요. 🎜rrreee🎜삽입 후 다음 문장을 이용하시면 생성문을 보실 수 있습니다. 🎜rrreee🎜UNIQUE 제약 조건을 삭제하려면 DROP INDEX 또는 ALTER TABLE 문을 사용할 수 있습니다. 🎜rrreee🎜기존 테이블에 추가하세요. 🎜rrreee

4.PRIMARY KEY

🎜보통 각 테이블에는 각 행을 고유하게 식별하는 값이 포함되어 있으며 이 열을 PRIMARY KEY라고 합니다. 🎜rrreee

5.FOREIGN KEY

🎜FOREIGN KEY는 테이블의 한 필드가 be another 한 테이블의 특정 필드에 존재하는 값이지만 다른 테이블에서는 이 열이 반드시 기본 키일 필요는 없지만 고유 인덱스여야 합니다. 그렇지 않으면 생성이 실패합니다. 🎜🎜예를 들어 주문 테이블의 userId는 user 테이블의 id를 참조해야 합니다. 삽입된 userId가 user 테이블에 없으면 삽입할 수 없습니다. 🎜rrreee🎜그런데 메인 테이블(사용자)의 레코드가 삭제되거나 업데이트되면 주문에 있는 레코드는 어떻게 되나요? , 아래 예시와 같이 오류가 직접 보고되는 것을 확인할 수 있습니다. 🎜rrreee🎜MySQL은 이러한 유형의 문제를 해결하는 데 도움이 되는 몇 가지 제약 조건을 제공합니다. 예를 들어 사용자 테이블이 업데이트되면 주문도 차례로 업데이트됩니다. 🎜
    🎜🎜RESTRICT: 하위 테이블에 레코드가 있는 경우 상위 테이블의 레코드 업데이트 또는 삭제를 거부합니다. 🎜🎜🎜CASCADE: 상위 테이블의 레코드를 업데이트하거나 삭제할 때 하위 테이블의 레코드를 자동으로 업데이트하거나 삭제합니다. 🎜🎜🎜SET NULL: 상위 테이블 레코드를 업데이트하거나 삭제할 때 하위 테이블의 필드 값을 null로 설정합니다. 🎜
🎜기본적으로 RESTRICT가 사용되는 것을 볼 수 있는데, 업데이트 시에도 업데이트되고 삭제 시에는 null이 설정되도록 수정해 보겠습니다. 🎜rrreee🎜테스트 업데이트 🎜rrreee🎜테스트 삭제. 🎜rrreee

6.DEFAULT

🎜DEFAULT 제약 조건은 열의 기본값을 설정하는 데 사용됩니다. 필드에 값이 할당되면 시스템이 자동으로 이 필드에 대한 기본값을 삽입합니다. 할당이 없다는 것은 데이터를 삽입할 때 이 필드가 지정되지 않음을 의미합니다. 결국. 🎜rrreee🎜🎜원본 주소: https://juejin.cn/post/7000352993572814885🎜🎜저자: i Listen to the Wind Passing Night🎜🎜🎜더 많은 프로그래밍 관련 지식을 보려면 🎜프로그래밍 비디오🎜를 방문하세요! ! 🎜

위 내용은 MySQL의 6가지 일반적인 제약 조건 유형에 대한 심층 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 juejin.cn에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제