집 >데이터 베이스 >MySQL 튜토리얼 >MySQL의 6가지 일반적인 제약 조건 유형에 대한 심층 분석
제약조건의 문자 그대로의 의미는 작업을 수행하는 방법을 규정하거나 제한하는 것입니다. MySQL에서 제약조건은 데이터 테이블의 데이터에 대한 규칙을 지정하는 것입니다. 즉, 신뢰성을 보장하기 위해 데이터를 제한하는 것입니다. 실제로 특정 열에는 Null 값이 나타날 수 있습니다. 실제로 다음과 같은 유형의 제약 조건이 발생합니다.
NOT NULL
: 열이 NULL 값을 가질 수 없는지 확인NOT NULL
: 确保列不能有NULL值CHECK
: 确保列中的值满足特定条件UNIQUE
: 确保一列中的所有值都不同PRIMARY KEY
: NOT NULL
和UNIQUE
组合,唯一标识表中的每一行FOREIGN KEY
: 外键约束DEFAULT
: 如果未指定值,则为列设置默认值【相关推荐:mysql视频教程】
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
如果想在列上定义条件约束,可以使用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 'user_chk_1' 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 'user_chk_1' is violated. mysql>
也可以进行多列约束,如年龄必须大于18,城市必须为中国。
mysql> create table user(age int(11),city varchar(255) ,check(age>18 and city='中国')); Query OK, 0 rows affected, 1 warning (0.05 sec)
插入测试。
mysql> insert user values(81,'2'); ERROR 3819 (HY000): Check constraint 'user_chk_1' is violated. mysql> insert user values(8,'2'); ERROR 3819 (HY000): Check constraint 'user_chk_1' is violated. mysql> insert user values(20,'2'); ERROR 3819 (HY000): Check constraint 'user_chk_1' is violated. mysql> insert user values(20,'中国'); Query OK, 1 row affected (0.01 sec) mysql> insert user values(20,'中国1'); ERROR 3819 (HY000): Check constraint 'user_chk_1' is violated. mysql> insert user values(85,'中国'); Query OK, 1 row affected (0.01 sec) mysql> insert user values(9,'中国'); ERROR 3819 (HY000): Check constraint 'user_chk_1' is violated.
还可以让列值必须在指定集合中,如性别必须在男、女、未知、人妖集合中。
mysql> create table user(sex varchar(255) check (sex in ('男','女','未知','人妖'))); 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 'user_chk_1' 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 'CHK_AGE' 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)));
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 '张三' for key 'user.name'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 '张三' for key 'user.name_un' 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 INDEX
或ALTER 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
通常每个表中包含一个用于唯一标识每一行的值,这个列就被称为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 '1' for key 'user.PRIMARY'mysql>
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也相继更新。
RESTRICT:如果子表中有记录,则拒绝更新或删除父表中的记录。
CASCADE:更新或删除父表中的记录时,自动更新或删除子表中的记录。
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)
DEFAULT
CHECK
: 열의 값이 특정 조건을 충족하는지 확인
UNIQUE
: 열의 모든 값이 다른지 확인PRIMARY KEY
:NOT NULL
과의 조합 UNIQUE
, 고유 식별자 테이블의 각 행
FOREIGN KEY
: 외래 키 제약 조건DEFAULT
: 값이 지정되지 않은 경우 , 열의 기본값 설정 li>【관련 권장사항: mysql 비디오 튜토리얼
】
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 값을 삽입하려면 예외가 발생합니다.
NOT NULL
제약 조건을 추가하세요. 🎜rrreee🎜 NOT NULL
제약 조건을 제거하세요. 🎜rrreeeUNIQUE
제약 조건은 열에 중복된 값이 없도록 보장합니다. , UNIQUE
및 PRIMARY KEY
제약 조건은 모두 열 값의 고유성을 보장하지만 UNIQUE
는 각 테이블에 여러 번 나타날 수 있습니다. code>PRIMARY KEY는 하나만 나타날 수 있습니다. 🎜🎜예를 들어 아래 이름 필드는 중복될 수 없습니다. 🎜rrreee🎜삽입 테스트. 🎜rrreee🎜이 제약 조건의 이름을 지정하고 삭제하세요. 🎜rrreee🎜삽입 후 다음 문장을 이용하시면 생성문을 보실 수 있습니다. 🎜rrreee🎜UNIQUE
제약 조건을 삭제하려면 DROP INDEX
또는 ALTER TABLE
문을 사용할 수 있습니다. 🎜rrreee🎜기존 테이블에 추가하세요. 🎜rrreeeFOREIGN KEY
는 테이블의 한 필드가 be another 한 테이블의 특정 필드에 존재하는 값이지만 다른 테이블에서는 이 열이 반드시 기본 키일 필요는 없지만 고유 인덱스여야 합니다. 그렇지 않으면 생성이 실패합니다. 🎜🎜예를 들어 주문 테이블의 userId는 user 테이블의 id를 참조해야 합니다. 삽입된 userId가 user 테이블에 없으면 삽입할 수 없습니다. 🎜rrreee🎜그런데 메인 테이블(사용자)의 레코드가 삭제되거나 업데이트되면 주문에 있는 레코드는 어떻게 되나요? , 아래 예시와 같이 오류가 직접 보고되는 것을 확인할 수 있습니다. 🎜rrreee🎜MySQL은 이러한 유형의 문제를 해결하는 데 도움이 되는 몇 가지 제약 조건을 제공합니다. 예를 들어 사용자 테이블이 업데이트되면 주문도 차례로 업데이트됩니다. 🎜DEFAULT
제약 조건은 열의 기본값을 설정하는 데 사용됩니다. 필드에 값이 할당되면 시스템이 자동으로 이 필드에 대한 기본값을 삽입합니다. 할당이 없다는 것은 데이터를 삽입할 때 이 필드가 지정되지 않음을 의미합니다. 결국. 🎜rrreee🎜🎜원본 주소: https://juejin.cn/post/7000352993572814885🎜🎜저자: i Listen to the Wind Passing Night🎜🎜🎜더 많은 프로그래밍 관련 지식을 보려면 🎜프로그래밍 비디오🎜를 방문하세요! ! 🎜위 내용은 MySQL의 6가지 일반적인 제약 조건 유형에 대한 심층 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!