MySQL约束

一、概述

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

二、目的

保证数据库中数据的正确、有效性和完整性

三、分类

约束描述关键字
非空约束限制该字段的数据不能为nullnot null
唯一约束保证该字段的所有数据都是唯一、不重复的unique
主键约束主键是一行数据的唯一标识,要求非空且唯一primary key
默认约束保存数据时,如果未指定该字段的值,则采用默认值default
检查约束保证字段值满足某一个条件check
外键约束让两张表的数据之间建立连接,保证数据的一致性和完整性foreign key

四、实例分析

字段名字段含义字段类型约束条件约束关键字
idID唯一标识int主键,并且自动增长primary key,auto_increment
name姓名varchar(10)不为空,并且唯一not null,unique
age年龄int大于0并且小于等于120check
status状态char(1)如果没有指定该值,默认为1default
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 && age<=120) comment '年龄',
     status char(1) default '1' comment '状态',
     gender char(1) comment '性别'
     )comment '用户表';

五、外键约束

作用:让两张表的数据之间建立连接,从而保证数据的一致性和完整性

添加外键

1、create table 表名(
                  字段名 数据类型
                   ......
                  [constraint] [外键名称] foreign key(外键字段名) references 主表(主表列名)
);
2、alter table 表名 add constraint 外键名称 foreign key(外键字段名) references 主表(主表列名)

删除外键:

alter table 表名 drop foreign key 外键名称

删除/更新行为

行为说明
no action当父表中删除/更新对应记录时,首先检查记录是否有对应外键,如果有则不允许删除/更新
restrict当父表中删除/更新对应记录时,首先检查记录是否有对应外键,如果有则不允许删除/更新
cascade当父表中删除/更新对应记录时,首先检查记录是否有对应外键,如果有,则也删除/更新外键在子表中的记录
set null当父表中删除对应记录时,首先检查记录是否有对应外键,如果有则设置子表中该外键值为null(要求外键允许取null)
set default父表有变更时,子表将外键列设置成一个默认的值

alter table 表名 add constraint 外键名称 foreign key(外键字段名) references 主表(主表列名) on updata(更新时) 行为 on delete(删除时) 行为

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值