MySQL:约束

目录

创建非空约束:NOT NULL关键字

创建唯一约束:UNIQUE关键字

创建主键约束:PRIMARY KEY关键字

*创建主键自增:AUTO_INCREMENT关键字

创建外键约束:FOREIGN KEY关键字

*级联操作

*添加级联操作:


约束

对表中的数据进行限定,保证数据的正确性、有效性和完整性

1.主键约束:primary key
2.非空约束:not null
3.唯一约束:unique
4.外键约束:foreigh key

 

创建非空约束:NOT NULL关键字

1.创建表时添加:

CREATE TABLE 表名(
    字段名 数据类型 NOT NULL
);

2.创建表后添加:

ALTER TABLE 表名 MODIFY 字段名 数据类型 NOT NULL

3.删除约束

ALTER TABLE 表名 MODIFY 字段名 数据类型;

 

创建唯一约束:UNIQUE关键字

1.创建表时添加:

CREATE TABLE 表名(
    字段名 数据类型 unique
);

2.创建表后添加:

ALTER TABLE 表名 MODIFY 字段名 数据类型 UNIQUE;

3.删除约束:

ALTER TABLE 表名 DROP INDEX 字段名;

 

创建主键约束:PRIMARY KEY关键字

*主键非空且唯一,一张表只能有一个主键!

1.创建表时:

CREATE TABLE 表名(
    字段名 数据类型 PRIMARY KEY
);

2.创建表后:

ALTER TABLE 表名 MODIFY 字段名 数据类型 PRIMARY KEY;

3.删除约束:

ALTER TABLE 表名 DROP PRIMARY KEY;

 

*创建主键自增:AUTO_INCREMENT关键字

*如果某一列是数值类型的,使用AUTO_INCREMENT可以完成值的自增长

1.创建表时:

CREATE TABEL 表名(
    字段名 数据类型 PRIMARY KEY AUTO_INCREMENT -- 可以配合主键使用
);

2.创建表后:

ALTER TABLE 表名 MODIFY 字段名 数据类型 AUTO_INCREMENT;

3.删除约束:

ALTER TABLE 表名 MODIFY 字段名 数据类型;

 

创建外键约束:FOREIGN KEY关键字

有些表内的字段相同,即为冗余。为了去掉这些冗余,可以将表拆分

1.创建表时添加:

CREATE TABLE 表名(
    字段名 数据类型,
    CONSTRAINT 外键名称 FOREIGN KEY (外键字段名) REFERENCES 主表名(主表的主键)
);

2.创建表后添加:

ALTER TABLE 添加外键的表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名) REFERENCES 主表名(主表的主键);

3.删除外键:

ALTER TABLE 外键的表名 DROP FOREIGN KEY 外键名;

 

*级联操作

前面设置的外键约束使得对主表字段的修改、删除进行了限制,使用级联操作使得主键可以修改/删除,而且删除后会将与之关联的外键一起修改/删除。不过要慎重进行该操作

可视化观察级联:在SQLyog中打开"架构设计器",将表拖进来,可以看到有外键关联的两个表或多个表之间有线连起来

*1-∞:1对多关系,其中1是主键

 

*添加级联操作:

1.添加级联更新:

ALTER TABLE 表名 ADD CONSTRAINT 外键名 FOREIGN KEY (外键字段名称)
REFERENCES 主表名(主表列名) ON UPDATE CASCADE;

2.添加级联删除

ALTER TABLE 表名 ADD CONSTRAINT 外键名 FOREIGN KEY (外键字段名称) 
REFERENCES 主表名(主表列名) ON DELETE CASCADE;

3.我全都要!

ALTER TABLE 表名 ADD CONSTRAINT 外键名 FOREIGN KEY (外键字段名称) 
REFERENCES 主表名(主表列名) ON UPDATE CASCADE ON DELETE CASCADE;

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值