MySQL创建表时添加约束

创建表时添加约束

①列级约束

演示:

sql 复制代码
CREATE TABLE students(
id INT PRIMARY KEY,#主建约束(唯一性,非空)
s_name VARCHAR(10) NOT NULL, #非空
s_sex CHAR(1) CHECK(s_sex='男' OR s_sex='女'),#检查约束(Mysql无效)
s_seat INT UNIQUE,#唯一约束
age INT DEFAULT 18, #默认约束
major_id INT REFERENCES majors(id) #这是外键,写在列级,Mysql无效
)
CREATE TABLE majors(
id INT PRIMARY KEY,
m_name VARCHAR(20) NOT NULL
)

②表级约束

sql 复制代码
DROP TABLE IF EXISTS students;
CREATE TABLE students(
id INT ,
s_name VARCHAR(10) ,
s_sex CHAR(1),
s_seat INT,
age INT ,
major_id INT , #这里下面有表级约束,要隔开,有逗号
CONSTRAINT pk PRIMARY KEY(id),#为id添加主建约束,pk是起的名,后面一样
CONSTRAINT uq UNIQUE(s_seat),#唯一性约束
CONSTRAINT ck CHECK(s_sex='男' OR s_sex='女'),#查询约束
CONSTRAINT fk_students_majors FOREIGN KEY(major_id) REFERENCES majors(id)#外键约束
);

总结一下表级约束的语法

【constraint 约束名字】 约束类型(字段名称) 【额外的东西,如外键】

一般情况下MySQL的约束

主建,非空,唯一性,默认等这些写在列级

外键约束写在表级!

相关推荐
百***49007 分钟前
Redis-配置文件
数据库·redis·oracle
老纪的技术唠嗑局10 分钟前
OceanBase 年度发布会 Hands-on AI Workshop 回顾
数据库
艾体宝IT13 分钟前
艾体宝干货 | Redis Python 开发系列#5 高可用与集群部署指南
数据库
d***956215 分钟前
docker 安装 mysql
mysql·adb·docker
雨中飘荡的记忆18 分钟前
MySQL 优化实战
java·mysql
3***891922 分钟前
开放自己本机的mysql允许别人连接
数据库·mysql·adb
X***C86226 分钟前
使用bitnamiredis-sentinel部署Redis 哨兵模式
数据库·redis·sentinel
f***019328 分钟前
CC++链接数据库(MySQL)超级详细指南
c语言·数据库·c++
q***235729 分钟前
MySQL 篇 - Java 连接 MySQL 数据库并实现数据交互
java·数据库·mysql
W***952431 分钟前
在Spring Boot项目中使用MySQL数据库
数据库·spring boot·mysql