Mysql应用MySQL学习笔记4:完整性约束限制字段
发布时间:2020-12-12 00:58:54 所属栏目:MySql教程 来源:网络整理
导读:《Mysql应用MySQL学习笔记4:完整性约束限制字段》要点: 本文介绍了Mysql应用MySQL学习笔记4:完整性约束限制字段,希望对您有用。如果有疑问,可以联系我们。 完整性约束是对字段进行限制,从而符合该字段达到我们期望的效果比如字段含有默认值,不能是NULL
《Mysql应用MySQL学习笔记4:完整性约束限制字段》要点: 直观点说:如果插入的数据不满足限制要求,数据库管理系统就拒绝执行操作 设置表的主键 主键能够标识表中每条信息的唯一性,如同身份证号码和人的关系 人可以同名,但是身份证号码却是唯一的, 创建主键的目的在于快速查找到表中的某一条信息 单字段主键 代码如下: mysql> create table student( -> id int primary key, -> name varchar(20), -> sex boolean -> ); Query OK,0 rows affected (0.09 sec) 创建了三个字段,其中id为主键 多字段主键 多字段主键由多个属性组合而成,在属性定义完之后统一设置主键 代码如下: mysql> create table student2( -> id int, -> course_id int, -> score float, -> primary key(id,course_id) -> ); Query OK,0 rows affected (0.11 sec) student2表有三个字段,其中id和course_id的组合可以确定唯一的一条记录 设置表的外键 表的外键与主键是相对应的,比如表A中的id是外键,表B中的id是主键 那么就可以称表B为父表,表A为子表 设置表外键的作用在于建立与父表的联系,比如表B中id为123的学生删除后,表A中id为123的记录也随着消失 这样做的目的在于保证表的完整性 代码如下: mysql> create table student3( -> id int primary key, -> teacher varchar(20), -> constraint fk foreign key(id,course_id) -> references student2(id,0 rows affected (0.12 sec) 这里创建student3表,constraint后面的fk是外键别名,foreign key也就是设置外键的字段 references后的内容表示父表,和父表中的主键 需要注意的是,父表中的主键不能为空,并且主键和外键的数据类型要一致 设置表的非空约束 非空性很好理解,就是设置表中字段的值不能为空(NULL) 如果在已经设置此约束性条件的字段中插入空值,数据库系统则会报错 代码如下: mysql> create table student4( -> id int not null,0 rows affected (0.10 sec) 这里的not null就是约束条件 设置表的唯一性约束 唯一性是指表中该字段的值不能重复出现,设置表的唯一性约束 也就是给表中某个字段加上unique 代码如下: mysql> create table student5( -> id int unique, -> name varchar(20) -> ); Query OK,0 rows affected (0.10 sec) 此处id字段便不可重复 设置表的属性值自动增加 auto_increment主要用于为表中插入的新记录自动生成唯一的ID 一个表只能有一个字段使用auto_increment约束 并且该字段必须为主键的一部分 代码如下: mysql> create table student6( -> id int primary key auto_increment,0 rows affected (0.12 sec) 这里的id是主键,并且会自动增加id值,比如1,2,3,4…… 需要注意的是,auto_increment约束的值必须是整数类型 设置表中属性的默认值 在表中插入一条新的记录时,如果没有为该字段赋值 那么数据库系统会自动为该字段赋上一条默认值 代码如下: mysql> create table student7( -> id int primary key, -> score int default 0 -> ); Query OK,0 rows affected (0.10 sec) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |