MySQL基础——常见的约束

MySQL基础——常见的约束

约束的含义:

一种限制,用于限制表中的数据,为了保证表中的数据的准确和可靠性

MySQL约束主要分为六大类:not null、default、primary key、unique、check、foreign key

六大约束
	1. Not null :非空,用于保证该字段的值不能为空
		比如姓名、学号等
	2. Default:默认,用于保证该字段有默认值
		比如性别
	3. Primary key:主键,用于保证该字段的值具有唯一性,并且非空
		比如学号、员工编号等
	4. Unique:唯一,用于保证该字段的值具有唯一性,可以为空
比如座位号
	5. Check:检查约束(mysql中不支持)
比如年龄、性别
	6. Foreign key:外键,用于限制两个表的关系,用于 保证该字段的值必须来自于主表的关联列的值
	在从表添加外键约束,用于引用主表中某列的值,比如学生表的专业编号,员工表的部门编号,员工表的工种编号。

添加约束的时机:

1.	创建表时
2.	修改表时

约束的添加分类:

	列级约束:六大约束语法上都支持,但外键约束没有效果
	表级约束:除了非空、默认,其他的都支持

添加约束的格式:

	Create table 表名(
		字段名 字段类型 约束
)

主键和唯一的对比:

			保证唯一性	是否允许为空	 	一个表中可以有多少个	    是否允许组合
	主键		1			0					至多有一个		可以,但不推荐
	唯一		1			1					可以有多个		可以,但不推荐

外键:

1.	要求在从表设置外键关系
2.	从表的外键列的类型和主表的关联列的类型要求一致或兼容,名称无要求
3.	主表的关联列必须是一个key(一般是主键或唯一)
4.	插入数据时,先插入主表,再插入从表
删除数据时,先删除从表,再删除主表

一、创建表时添加约束

1. 添加列级约束

语法:

直接在字段名和类型后面追加 约束类型即可

只支持:

默认、非空、主键、唯一
Use students;

Create table stuinfo(
	Id int primary key, #主键
	Stuname varchar(20) not null, #非空
	Gender char(1) check(gender=’男’ or gender=’女’), #检查
	Seat int unique, #唯一
	Age int default 18, #默认约束
	Majorid int references major(id) #外键
);

Create table major(
	Id int primary key,
	Majorname varchar(20)
);
2. 添加表级约束

语法:

在各个字段的最下面
Constraint 约束名 约束类型(字段名)
Drop table if exists stuinfo;

Create table stuinfo(
	
	Id int,
	Stuname varchar(20),
	Gender char(1),
	Seat int,
	Age int,
	Majored int,
	
	Constraint pk primary key(id), #主键
	Constraint uq unique(seat), #唯一键
	Constraint ck check(gender = ‘男’ or gender = ‘女’)#检查
	Constraint fk_stuinfo_major foreign key(majorid) references major(id) #外键
);

Show index from stuinfo;

二、修改表时添加约束

语法:

1.	添加列级约束
	a)	Alter table 表名 modify column 字段名 字段类型 新约束;
2.	添加表级约束
	a)	Alter table 表名 add [constraint 约束名] 约束类型(字段名) 【外键的引用】
1. 添加非空约束
Alter table stuinfo modify column stuname varchar(20) not null;
2. 添加默认约束
Alter table stuinfo modify column age int default 18;
3.添加主键约束
#列级约束
Alter table stuinfo modify column id int primary key;
#表级约束
Alter table stuinfo add primary key(id);
4.添加唯一约束
#列级约束
Alter table stuinfo modify column seat int unique;
#表级约束
Alter table stuinfo add unique(seat);
5.添加外键约束
Alter table stuinfo add foreign key(majorid) references major(id);

三、修改表时删除约束

1.删除非空约束
Alter table stuinfo modify column stuname varchar(20) null;
2.删除默认约束
Alter table stuinfo modify column age int;
3.删除主键
Alter table stuinfo drop primary key;
4.删除唯一
Alter table stuinfo drop index seat;
5.删除外键
Alter table stuinfo drop foreign key fk_stuinfo_major;

Show index from stuinfo;
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值