深圳专业商城网站设计,苏州网站seo优化,360网站seo,腾讯风铃做的网站有期限吗为防止错误的数据被插入到数据表#xff0c;MySQL中定义了一些维护数据库完整性的规则#xff1b;这些规则常称为表的约束。常见约束如下#xff1a; 主键约束 主键约束即primary key用于唯一的标识表中的每一行。被标识为主键的数据在表中是唯一的且其值不能为空。这点类似…为防止错误的数据被插入到数据表MySQL中定义了一些维护数据库完整性的规则这些规则常称为表的约束。常见约束如下 主键约束 主键约束即primary key用于唯一的标识表中的每一行。被标识为主键的数据在表中是唯一的且其值不能为空。这点类似于我们每个人都有一个身份证号并且这个身份证号是唯一的。 主键约束基本语法
字段名 数据类型 primary key;设置主键约束(primary key)的第一种方式 示例MySQL命令
create table student(
id int primary key,
name varchar(20)
);非空约束 非空约束即 NOT NULL指的是字段的值不能为空基本的语法格式如下所示
字段名 数据类型 NOT NULL;示例MySQL命令
create table student02(
id int
name varchar(20) not null
);默认值约束 默认值约束即DEFAULT用于给数据表中的字段指定默认值即当在表中插入一条新记录时若未给该字段赋值那么数据库系统会自动为这个字段插人默认值其基本的语法格式如下所示
字段名 数据类型 DEFAULT 默认值示例MySQL命令
create table student03(
id int,
name varchar(20),
gender varchar(10) default male
);唯一性约束 唯一性约束即UNIQUE用于保证数据表中字段的唯一性即表中字段的值不能重复出现其基本的语法格式如下所示
字段名 数据类型 UNIQUE; 示例MySQL命令
create table student04(
id int,
name varchar(20) unique
);外键约束 外键约束即FOREIGN KEY常用于多张表之间的约束。基本语法如下
-- 在创建数据表时语法如下
CONSTRAINT 外键名 FOREIGN KEY (从表外键字段) REFERENCES 主表 (主键字段)
-- 将创建数据表创号后语法如下
ALTER TABLE 从表名 ADD CONSTRAINT 外键名 FOREIGN KEY (从表外键字段) REFERENCES 主表 (主键字段);示例创建一个学生表 MySQL命令
create table student05(
id int primary key,
name varchar(20)
);
示例创建一个班级表 MySQL命令
create table class(
classid int primary key,
studentid int
);
示例学生表作为主表班级表作为副表设置外键 MySQL命令
alter table class add constraint fk_class_studentid foreign key(studentid) references student05(id);数据一致性概念 大家知道建立外键是为了保证数据的完整和统一性。但是如果主表中的数据被删除或修改从表中对应的数据该怎么办呢很明显从表中对应的数据也应该被删除否则数据库中会存在很多无意义的垃圾数据。
删除外键 语法如下
alter table 从表名 drop foreign key 外键名示例删除外键 MySQL命令
alter table class drop foreign key fk_class_studentid;关于外键约束需要注意的细节 1、从表里的外键通常为主表的主键 2、从表里外键的数据类型必须与主表中主键的数据类型一致 3、主表发生变化时应注意主表与从表的数据一致性问题