当前位置:网站首页>MySQL-DDL数据定义语言-约束

MySQL-DDL数据定义语言-约束

2022-08-03 08:36:00 LXMXHJ

约束

概念
约束,是一种限制,用于限制表中的数据,确保表中数据的准确性和可靠性。

分类:六大约束

约束含义作用案例
not null非空保证该字段的值不为空比如姓名、学号等
default默认约束保证该字段有默认值比如性别
primary key主键保证该字段的值具有唯一性,且非空学号、员工编号
unique唯一约束保证该字段的值具有唯一性,可以为空座位号
check检查约束检查数据表中字段值有效性性别、年龄
foreign key外键限制两个表的关系,保证该字段值的值必须来自于主表的关联列的值
在从表添加外键约束,用于引用主表中某列的值。
学生表的专业编号、员工表的部分编号、员工表的工种编号

添加约束时机
创建表、修改表

创建表添加约束

列级约束、表级约束

列级约束

书写位置
直接在字段名和类型后面追加约束类型即可。

常见约束
默认(default)、非空(not null)、主键(primary key)、唯一(unique)。
六大约束语法上都支持,但是外键约束没有效果。

语法

create table 表名(
	字段名 字段类型 列级约束,
	字段名 字段类型 列级约束,
	.....

常见约束写法

约束具体写法
not null字段名 字段类型 not null
primary key字段名 字段类型 primary key
unique字段名 字段类型 unique
default字段名 字段类型 default 某值
check字段名 字段类型 check (字段 in(值1,值2))

案例
在这里插入图片描述
备注2022/8/1
命令show index from 表 # 输出该表中的所有索引。

表级约束

语法

在各个字段的最下面 [constraint 约束名] 约束类型 (字段名)

create table 表名(
	字段名 字段类型,
	字段民 字段类型,
	[constraint 约束名] 约束类型 (字段名),
	[constraint 约束名] 约束类型 (字段名),
)

常见约束
除了非空(not null)、默认(default),其他都支持

约束书写

约束具体书写
primary keyprimary key(字段名)
uniqueunique (字段名)
foreign keyforeign key(字段名)
checkcheck(字段名 in(值1,值2))

案例

在这里插入图片描述

通用写法

在这里插入图片描述
列级约束:unique、not null、default、primary key、check
表级约束:foreign key

create table 表名(
	字段名 字段类型 primary key,
	字段名 字段类型 default,
	字段名 字段类型 not null,
	字段名 字段类型 unique,
	检查字段名 字段类型 check(检查字段 in(值1,值2))
	外键字段 字段类型,
	constraint 约束名 foreign key(外键字段)references 所依赖的表(字段)
);

列级约束与表级约束比较

约束列级表级
位置列字段类型后面所有列的后面
支持约束所有约束都支持,但外键没有效果默认和非空不支持,其他都支持
约束起别名不可以可以,但主键约束没有效果

主键与唯一比较

约束主键唯一
是否具有唯一性
是否允许为空是(只允许一个为空)
表中存在个数最多一个可以有多个
是否允许组合是,但不推荐是,但不推荐

理解
唯一性中可以为空。只允许列中有一个为空,如果出现多个则会报错。

字段组合

  • 概念
    就是表级约束书写中共括号内是多个字段。

  • 语法:

primary key (字段1,字段2...unique(字段1,字段2....
  • 案例:
    在这里插入图片描述

外键的特点

语法

create table 从表(
	从表字段名 字段类型,
	[constraint 约束名] foreign key(从表字段名) references 主表(主表字段名)
);

特点

用于限制两个表的关系,从表的字段值引用了主表的某字段值。
从表外键列的类型和主表的被引用列的类型要求一致或兼容,名称无所谓。
主表的被引用列必须是一个key(一般是主键或唯一键)。
插入数据时,先插入主表,再插入从表。(先得有信息)
删除信息时,先删除从表,再删除主表。(先得删除引用)

删除主表的记录

  • 方式1 级联删除
alter table 从表名 add constraint 约束名 foreign key(外键列) references 主表(被引用列) on delete cascade;

删除从表的外键列的某个值(a值)
效果:从表外键列的a值被删除;主表被引用列中含有a值的行被删除;

  • 方式2 级联置空
alter table 从表名 add constraint 约束名 foreign key(外键列) references 主表(被引用列) on delete set null;

修改表添加约束

添加列级约束 语法

alter table 表名 modify [column] 字段名 字段类型 新约束;

添加表级约束 语法

alter table 表名 add[constraint 约束名] 约束类型(字段名) [外键的引用references 主表(主表列)];

具体约束添加

# 主键约束
alter table 表名 modify column 字段名 字段类型 primary key;
# 非空性约束
alter table 表名 modify column 字段名 字段类型 not null;
# 默认约束
alter table 表名 modify column 字段名 字段类型 default 默认值;

# 唯一性约束 列级
alter table 表名 modify column 字段名 字段类型 unique;
# 唯一性约束 表级
alter table 表名 add unique(字段名);

# 外键约束
alter table 从表 add foreign key(字段名) references 主表(主表字段名);

案例
在这里插入图片描述

修改表时删除约束

语法

# 删除not null、default、primary key
alter table 表名 modify column 字段名 字段类型;

# 删除primary key、unique、foreign key
alter table 表名 drop primary key/index 字段名 /foreign key 约束名;

案例

在这里插入图片描述
在这里插入图片描述

标识列(自增长列)

概述

含义

可以不用手动的插入值,系统提供默认的序列值。

特点

  • 标识列必须是一个key。
  • 一个表至多有一个自增长列。
  • 标识列的类型:只能是数值型,int、float、double都可以。
  • 不用手动插入值,可以自动提供序列值,默认从1开始,步长为1,
    通过这个(set auto_increment_increment)可以看到。
  • 如果要更改起始值:手动插入值;
    如果要更改步长:更改系统变量。
    set auto_increment_increment = 3;设置步长

设置标识列

创建表时设置 语法

create table 表名(
	字段 字段类型 约束 auto_increment,
	.....

创建表时设置 案例
在这里插入图片描述
备注

# 查询 auto_increment标识列
show variables like "%auto_increment%"

# 修改自增长的步长
set auto_increment_increment = 具体值;

在这里插入图片描述
修改表时设置标识列 语法

alter table 表名 modify column 字段 字段类型 约束 auto_increment;

删除表时删除标识列 语法

delete table 表名 modify column 字段 字段类型;
原网站

版权声明
本文为[LXMXHJ]所创,转载请带上原文链接,感谢
https://blog.csdn.net/LXMXHJ/article/details/126095138