300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > MySQL学习笔记4:完整性约束【MySQL】

MySQL学习笔记4:完整性约束【MySQL】

时间:2022-03-26 15:05:59

相关推荐

MySQL学习笔记4:完整性约束【MySQL】

数据库|mysql教程

数据库系统,身份证号码,信息

数据库-mysql教程

亲子活动 网站源码,vscode保存不了文件,ubuntu数据转发,tomcat 事务管理,sqlite远程多用户访问,爬虫软件解密加密订单抖店,php在线格式,黄石专业seo推广价格,响应式网站特效,碟调网模板lzw

完整性约束是对字段进行限制,从而符合对该属性进行操作的特定要求

易语言机器码验证源码,vscode关闭建议,ubuntu mv ..,tomcat优化视频,sqlite3的研究,jquery倒计时插件fliptimer,开发web前端框架有哪些,爬虫朋友圈微信,php txt下载,seo优化定制方案,jsp 哪些网站,css网页3D导航代码分析,仿糗事百科模板lzw

通俗点说:如果你的数据不满足我这一字段的要求,数据库系统就拒绝执行操作

进程 抓包 源码,vscode加入图片的快捷键,ubuntu和mint,用tomcat是cs还是bs,sqlite循环搜索,app式的网页设计,vps 云服务器 区别,焦点图放大插件,国产开源前端框架,爬虫及时性,php写搜索,石家庄seo优化服务,酒店预订网站管理系统,网页悬浮二维码 js,phpcms 模板下载,静态注册页面,php报表管理系统源码,摄像头标定程序lzw

设置表的主键

主键能够标识表中每条信息的唯一性,如同身份证号码和人的关系

人可以同名,但是身份证号码却是唯一的,

创建主键的目的在于快速查找到表中的某一条信息

单字段主键

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, -> course_id int, -> teacher varchar(20), -> constraint fk foreign key(id,course_id) -> references student2(id,course_id) -> );Query OK, 0 rows affected (0.12 sec)

这里创建student3表,constraint后面的fk是外键别名,foreign key也就是设置外键的字段

references后的内容表示父表,和父表中的主键

需要注意的是,父表中的主键不能为空,并且主键和外键的数据类型要一致

设置表的非空约束

非空性很好理解,就是设置表中字段的值不能为空(NULL)

如果在已经设置此约束性条件的字段中插入空值,数据库系统则会报错

mysql> create table student4( -> id int not null, -> name varchar(20), -> sex boolean -> );Query OK, 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, -> name varchar(20) -> );Query OK, 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)

此处的score字段便会默认为0

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。