十七、MySQL约束演示

1、约束定义

(1)概念

约束,顾名思义,时作用域表中字段上的规则,用于限制存储在表中的数据,主要用于保证数据库中数据的正确、有效性和完整性。

(2)各种约束分类

sql 复制代码
1、非空约束(限制字段数据不能为null):
not null
2、唯一约束(保证该字段的所有数据都是唯一、不重复的):
这里需要注意,当某个字段有'唯一性'约束时,即便执行失败,也会占用一个主键位置
unique
3、主键约束(主键是一行数据的唯一标识,要求非空并唯一):
primary key
4、默认约束(保存数据时,如果未指定该字段的值,则采用默认值):
default
5、检查约束(保证字段值满足某一个条件):
check
6、外键约束(用来让两张表的数据之间建立连接,保证数据的一致性和完整性):
foreign key

2、实际操作

(1)先创建一个基础表:

sql 复制代码
use other;
# 创建表结构
# 字段名 数据类型 约束 comment 注释;
create table user(
    -- 自增长
    id int primary key auto_increment comment '主键',
    -- 不能为null,而且不能重复,唯一性(即便执行失败,也会占用主键)
    name varchar(10) not null unique comment '姓名',
    -- 年龄范围(0~120)
    age int check ( age>0 && age<=120 ) comment '年龄'
)comment '用户表';
insert into user(name,age) values ('lom',12),('kom',56);
insert into user(name,age) values ('jom',34);

(2)验证name字段不能为null:

sql 复制代码
# 不能为null验证:该语句会执行失败
insert into user(name,age) values (null,78);

(3) 验证name字段唯一性:

sql 复制代码
insert into user(name,age) values ('lom',12);

此处name='lom'已存在,虽该语句会执行失败,但是其仍会申请一个主键,并占用,通过添加一组新的数据,观察主键值,来验证如下:

sql 复制代码
# 唯一约束验证:此处name='lom'已存在,虽该语句会执行失败,但是其仍会申请一个主键,并占用
insert into user(name,age) values ('hom',38);

(4)验证age字段范围:

sql 复制代码
# 年龄范围验证:该语句会执行失败,该语句会执行失败,因为-11小于0,121大于120
insert into user(name,age) values('fom',-11);
insert into user(name,age) values('dom',121);
相关推荐
至此流年莫相忘几秒前
Spring 依赖注入三剑客:@Autowired、@Resource 与 @RequiredArgsConstructor 深度对比与实战指南
java·数据库·spring
Rain5092 分钟前
2.2 数据基础:数据库集成与 ORM(TypeORM / Prisma)
数据库·人工智能·ai·数据分析·node.js·自动化·ai编程
杨云龙UP13 分钟前
Oracle/ODA RAC /u01 空间告警处理指南:grid 用户监听日志清理_2026-06-15
linux·数据库·oracle·oracle linux·oda·监听日志·在线清理
IT新视界20 分钟前
从多平台割裂到湖仓集一体,星环科技ArgoDB助力金融机构迈向实时智能
数据库·科技
master33622 分钟前
达梦数据库常用语句示例
数据库·达梦
Elastic 中国社区官方博客25 分钟前
Elasticsearch:使用向量搜索构建现代应用的最佳实践
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
Volunteer Technology35 分钟前
Flink状态管理与容错(一)
大数据·数据库·flink
CIO_Alliance1 小时前
(企业AI化转型)选对iPaaS系统集成厂家是制造业数字化转型的生死线
大数据·数据库·人工智能·企业数字化转型·ipaas·系统集成
南部余额1 小时前
Canal解决MySQL与Redis数据一致性问题
数据库·redis·mysql·canal·数据·数据同步
睡不醒男孩0308231 小时前
CLup篇之数据库传统运维对比
运维·数据库