MySQL的约束

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8" />

<title>Mysql的约束</title>

</head>

<body>

<!-- 约束

概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据

目的:保证数据库中数据的正确,有效性和完整性

分类:

非空约束:限制该字段的数据不能为null,

关键字:not null

唯一约束:保证该字段的所有数据都是唯一,不重复的

关键字:unique

主键约束:主键是一行数据的唯一标识,要求非空且唯一

关键字:primary key

默认约束:保存数据时,如果未指定该字段的值,则采用默认值

关键字:default

检查约束:保证字段值满足某一个条件

关键字:check

外键约束:用来让两张表的数据之间建立联系,保证数据的一致性和完整性

关键字:foreign key

注意:约束是作用于表中字段上的,可以在创建表/修改表的时候添加约束。

例子:

id 唯一标识 int 约束条件:主键,并且自动增长 约束关键字:primary key,auto_increment

name 姓名 varchar(10) 约束条件:不为空,并且唯一 约束关键字:not null,unique

age 年龄 int 约束条件:大于0,并且小于等于120 约束关键字:check

status 状态 char(1) 约束条件:如果没有指定该值,默认为1 约束关键字:default

gender 性别 char(1) 约束条件:无 约束关键字:无

根据上面创建表

create table user(

id int primary key auto_increment comment '主键',

name varchar(10) not null unique comment '姓名',

age int check (age >0 and age <=120) comment '年龄',

status char(1) default '1' comment '状态',

gender char(1) comment '性别'

)comment '用户表';

-->

<!-- 外键约束

概念:外键用来让两种表的数据之间建立连接,从而保证数据的一致性和完整性

注意:在数据库层面,未建立外键关联,是无法保证数据的一致性和完整性的。

添加外键

create table 表名(

字段名 数据类型,

...

constraint\] \[外键名称\] foreign key (外键字段名) references 主表(主表列名) ); alter table 表名 add constraint 外键名称 foreign key (外键字段名) references 主表(主表列名); 删除外键 alter table 表名 drop foreign key 外键名称; 删除/更新行为 no action:当父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。默认行为 restrict:当父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。默认行为 cascade:当父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则也删除/更新外键在子表中的记录 set null:当父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为null(这就要要求外键允许取null) set default:父表有变更时,子表将外键列设置成一个默认的值(innodb不支持) 语法:alter table 表名 add constraint 外键名称 foreign key (外键字段名) references 主表(主表列名)on update cascade on delete cascade; --\> \ \

相关推荐
逃逸线LOF2 分钟前
mysql本地计算机上的MySQL服务启动后停止。某些服务在未由其他服务或程序使用时将自动停止
数据库
Remember_99313 分钟前
MySQL 索引详解:从原理到实战优化
java·数据库·mysql·spring·http·adb·面试
dishugj20 分钟前
【Oracle】 rac的一些问题以及解决方案
数据库·oracle
Ronin30523 分钟前
日志打印和实用 Helper 工具
数据库·sqlite·rabbitmq·文件操作·uuid生成
eWidget24 分钟前
面向信创环境的Oracle兼容型数据库解决方案
数据库·oracle·kingbase·数据库平替用金仓·金仓数据库
阿正的梦工坊32 分钟前
使用即梦(seedream)来图生图:读取与写入飞书多维表格
数据库·飞书
Coder_Boy_39 分钟前
基于SpringAI的在线考试系统-整体架构优化设计方案(续)
java·数据库·人工智能·spring boot·架构·领域驱动
云飞云共享云桌面40 分钟前
推荐一些适合10个SolidWorks设计共享算力的服务器硬件配置
运维·服务器·前端·数据库·人工智能
Elastic 中国社区官方博客42 分钟前
Elasticsearch:使用 Base64 编码字符串加速向量摄取
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
大模型玩家七七1 小时前
安全对齐不是消灭风险,而是重新分配风险
android·java·数据库·人工智能·深度学习·安全