当前位置:Gxlcms > 数据库问题 > MySQL数据库操作(4)表约束

MySQL数据库操作(4)表约束

时间:2021-07-01 10:21:17 帮助过:12人阅读

CREATE TABLE tb1( id INT, name VARCHAR(20) NOT NULL ); INSERT INTO tb1(id) VALUE(1); # 报错,没有传入name #注意:在mysql 里面,‘‘ 不等于null #修改表添加非空约束 ALTER TABLE tb1 MODIFY id INT NOT NULL; #取消非空约束 ALTER TABLE tb1 MODIFY id INT;

 

唯一约束
`UNIQUE KEY` 确保字段中的值的唯一
例:

#创建表时添加唯一约束
CREATE TABLE tb2(id INT NOT NULL UNIQUE KEY, name VARCHAR(20) NOT NULL);
INSERT INTO tb2 VALUE(1,张三);
INSERT INTO tb2 VALUE(1,李四); # 报错,id字段的值有重复
#修改表添加唯一约束
ALTER TABLE `tb2` ADD UNIQUE KEY(`name`);
#删除唯一约束
ALTER TABLE tb2 DROP KEY name;
#联合唯一约束
ALTER TABLE tb2 ADD aa INT, add bb INT;
ALTER TABLE tb2 ADD UNIQUE KEY (aa,bb);
INSERT INTO tb2 VALUE(4,佳能,1,2);
INSERT INTO tb2 VALUE(5,哈哈,1,2); # 报错,(aa,bb)联合字段有重复
#删除联合唯一
SHOW CREATE TABLE tb2; #查看约束名
ALTER TABLE tb2 DROP KEY aa; #通过约束名删除约束,联合约束默认名为联合列中的第一列

 

主键约束
`PRIMARY KEY ` == `NOT NULL + UNIQUE KEY`
主键保证记录的唯一性, 唯一标识每一条数据
主键自动为`NOT NULL`
每张数据表只能存在一个主键
当一张表里没有一个主键的时候,第一个出现的非空且为唯一的列被视为有主键。
例:

#创建表时添加主键约束
CREATE TABLE tb3( id INT PRIMARY KEY,name VARCHAR(20) NOT NULL);
#删除主键约束
ALTER TABLE tb3 DROP PRIMARY KEY;
#添加主键约束
ALTER TABLE tb3 ADD PRIMARY KEY(id);
#联合主键
CREATE TABLE tb4(id_a INT , id_b INT, content VARCHAR(20), PRIMARY KEY(id_a,id_b) );
#添加联合主键
ALTER TABLE tb4 ADD PRIMARY KEY(id_a,id_b);

 

自增长
`AUTO_INCREMENT `自动编号,一般与主键组合使用。一个表里面只有一个自增
默认情况下,起始值为1,每次的增量为1。
当插入记录时,如果为`AUTO_INCREMENT`数据列明确指定了一个数值,则会出现两种情况,
情况一,如果插入的值与已有的编号重复,则会出现出错信息,因为AUTO_INCREMENT数据列的值必须是唯一的;
情况二,如果插入的值大于已编号的值,则会把该插入到数据列中,并使在下一个编号将从这个新值开始递增。也就是说,可以跳过一些编号。如果自增序列的最大值被删除了,则在插入新记录时,该值被重用。(可以调大,不可以缩小)
例:

#创建表时添加自增长
CREATE TABLE tb5( id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(20))AUTO_INCREMENT =100; # 如果不写,默认从1开始
#删除自动增长
ALTER TABLE tb5 MODIFY id INT;
#修改表添加自动增长
ALTER TABLE tb5 MODIFY id INT AUTO_INCREMENT;

 

默认约束
`DEFAULT `初始值设置,插入记录时,如果没有明确为字段赋值,则自动赋予默认值。
例:

#创建表时添加默认约束
CREATE TABLE tb6(id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(20) NOT NULL,age INT NOT NULL DEFAULT 18);
#删除默认约束
ALTER TABLE tb6 MODIFY age INT NOT NULL;
ALTER TABLE tb6 ALTER age DROP DEFAULT;
#添加默认约束
ALTER TABLE tb6 MODIFY age INT DEFAULT 20;
ALTER TABLE tb6 ALTER age SET DEFAULT 21;

 

外键约束
外键约束`FOREIGN KEY`,保持数据一致性,完整性实现一对一或一对多关系。
外键约束的要求:
数据表的存储引擎只能为InnoDB
外键列和参照列数据类型一致
外键必须关联到键上面去,一般情况是关联到,另一张表的主键
例:

#创建表时添加外键约束
CREATE TABLE `a`( a_id INT PRIMARY KEY,a_name VARCHAR(20) NOT NULL);
CREATE TABLE `b`(b_id INT PRIMARY KEY,b_name VARCHAR(20) NOT NULL,fy_id INT NOT NULL,CONSTRAINT AB_id FOREIGN KEY(fy_id) REFERENCES `a`(a_id)); #AB_id是外键的别名,如果没有别名则无法删除该外键,fy_id是本表中要关联的列,`a`(a_id)是关联到a表的a_id列,fy_id的取值必须在a表中的a_id列中出现过才能用。
#删除外键
ALTER TABLE `b` DROP FOREIGN KEY AB_id;
#增加外键
ALTER TABLE `b` add CONSTRAINT AB_id FOREIGN KEY(fy_id) REFERENCES `a`(a_id);

 

MySQL数据库操作(4)表约束

标签:拒绝   rem   创建   uniq   建表   mys   nbsp   报错   完整   

人气教程排行