【Hello mysql】 mysql的约束
Mysql专栏:@Mysql
本篇博客简介:介绍mysql的约束
mysql的约束
- 表的约束
- 空属性
- 默认值
- 列描述
- zerofill
- 主键
- 自增长
- 唯一键
- 外键
- 总结
表的约束
为什么要有约束?
我们在收集一些数据的时候会要求该数据必须存在
比如说像是国家在登记公民信息的时候身份证一栏是必须要填写的不能为空
真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合
法性,从业务逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的
表的约束很多,这里主要介绍如下几个: null/not null,default, comment, zerofill,primary
key,auto_increment,unique key 。
空属性
数据库默认字段基本都是字段为空,但是实际开发时,尽可能保证字段不为空,因为数据为空没办法参与运算
所以说对于一些属性我们要设置为非空
语法
not null
实例
我们这里创建一个班级表 其中包含班级名和所在的教室
在外面正常的逻辑中 班级和教室都是不能为空的
- 如果班级名为空我们就不知道自己在哪个班
- 如果教室为空我们就不知道自己在哪个教室
所以说我们在设计数据表的时候加上非空约束
默认值
默认值:某一种数据会经常性的出现某个具体的值,可以在一开始就指定好,在需要真实数据的时候,
用户可以选择性的使用默认值。
语法
default xxx
我们插入一个数据尝试
我们这里只插入了值zhangsna但是age和sex都自动填写了
有了default之后还需要设置非空嘛?
不需要 因为如果我们没有填值的话 系统会给我们填上默认值 所以说就不存在空值的情况了
列描述
列描述:comment,没有实际含义,专门用来描述字段,会根据表创建语句保存,用来给程序员或DBA来进行了解。
语法
comment ‘xxx’
此外我们可以通过查看创建语句来看到对于每个列的描述
实例
zerofill
刚开始学习数据库时,很多人对数字类型后面的长度很迷茫
比如说在下图中 int类型后面的11是什么意思呢?
整型不是4字节码?这个10又代表什么呢?其实没有zerofill这个属性,括号内的数字是毫无意义的
此时我们修改t8中age类型的属性 在后面加上zerofill
此时我们发现age的18前面补上了三个0
也就是说zerofill的意义其实是看该类型有没有达到指定的位数 如果没有达到就在前面加上0填充
主键
主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;主键所在的列通常是整数类型。
语法
primary key
实例
我们创建一张表 id作为主键 name作为非空列
主键约束
主键中的值不能重复 一旦重复就会报错 下面是示例
我们可以看到插入重复id时sql直接报错了
删除主键
语法
alter table 表名 drop primary key;
添加主键
语法
alter table 表名 add primary key(字段列表)
复合主键
在创建表的时候,在所有字段之后,使用primary key(主键字段列表)来创建主键,如果有多个字段
作为主键,可以使用复合主键
比如说在创建学生的课程表的时候学生id和课程号都是可以重复的 但是学生id和课程号的组合确是不能重复的 所以说我们要将他们设置为复合主键
语法
primary key(xxx , yyy)
自增长
auto_increment:当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值+1操作,得到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。
自增长的特点:
- 任何一个字段要做自增长,前提是本身是一个索引(key一栏有值)
- 自增长字段必须是整数
- 一张表最多只能有一个自增长
关于索引是什么概念 我们后面的博客会讲解
语法:
auto_increment
下面是实例
我们开始插入名字 之后查看id的变化情况
我们发现id数据是从1开始依次往后递增
那么如果我们现在插入一个id为1000的数据之后的id会如何变化呢?
我们可以发现后面的id从1001开始自增了
唯一键
在了解唯一键之前我们首先要明白一个概念
并不是因为我们选择一个属性成为了主键这个属性才具有了唯一性 而是我们选择了一个具有唯一性的属性成为了主键
也就是说除了主键之间还有很多数据也可能具有唯一性 这也就是我们唯一键出现的原因
语法
unique
下面是实例
当一个数据成为唯一键之后那么这个数据就不能重复了
外键
外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。
当定义外键后,要求外键列数据必须在主表的主键列存在或为null。
我们先来看最后一句加粗的话 也就是说主表中必须有数据从表中才能插入数据
语法:
foreign key (class_id) references myclass(id)
下面是实例 我们先创建主表 之后再从表中创建外键约束
我们首先像从表中插入数据尝试
我们可以发现主表中如果没有插入数据从表中是不能插入的
而主表中有数据 从表中就可以插入数据了
而我们删除数据的时候必须要先删除从表中的数据才能删除主表
这里总结下
- 外键是在从表中定义的
- 从表添加数据必须主表先添加
- 主表删除数据必须从表先删除
我们如何理解外键约束
首先这是一种约束 它肯定是为了防止我们做出错误或不符合逻辑的操作的
理论上,上面的例子,我们不创建外键约束,就正常建立学生表,以及班级表,该有的字段我们都有。
但是实际过程中由于可能会由于人为操作的失误而造成一些错误 比如说一些数据只有学生表中有 而不存在于班级表中(这样就不知道这个学生在哪个班了)
所以说我们添加外键约束是必须的 它的本质其实就是将插入和删除数据的合法性交给mysql去审核
总结
【Hello mysql】 mysql的约束相关推荐
- mysql 索引与约束_MySQL之索引与约束条件
字段约束 作用 顾名思义就是给字段加以限制 其保证数据库的完整性与一致性 通过约束条件防止数据库产生一些不必要的数据 保证数据库的正确性 相容性 安全性 null和not null mysql> ...
- MySQL外键约束On Delete、On Update各取值的含义
主键.外键和索引的区别? 主键 外键 索引 定义: 唯一标识一条记录,不能有重复的,不允许为空 表的外键是另一表的主键, 外键可以有重复的, 可以是空值 主索引(由关键字PRIMARY定义的索引) ...
- MySQL非空约束(NOT NULL)
MySQL 非空约束(NOT NULL)可以通过 CREATE TABLE 或 ALTER TABLE 语句实现.在表中某个列的定义后加上关键字 NOT NULL 作为限定词,来约束该列的取值不能为空 ...
- mysql添加枚举约束语句_mysql8 参考手册--MySQL如何处理约束
MySQL使您既可以使用允许回滚的事务表,也可以使用不允许回滚的非事务表.因此,MySQL中的约束处理与其他DBMS中的约束处理有所不同.当您在非事务处理表中插入或更新了很多行时,如果发生错误,则无法 ...
- mysql中索引约束有哪些_Mysql中索引和约束的示例语句
外键 查询一个表的主键是哪些表的外键 SELECT TABLE_NAME, COLUMN_NAME, CONSTRAINT_NAME, REFERENCED_TABLE_NAME, REFERENCE ...
- mysql 外键约束_MySQL之外键约束(FOREIGN KEY)
定义: MySQL外键约束(FOREIGN KEY)用来在两个表的数据之间建立链接,它可以是一列或者多列.一个表可以有一个或多个外键. 外键对应的是参照完整性,一个表的外键可以为空值,若不为空值,则每 ...
- 一、TCL事务控制语言 二、MySQL中的约束 三、多表查询(重点) 四、用户的创建和授权 五、MySQL中的索引...
一.TCL事务控制语言 ###<1>事务的概念 事务是访问并可能更新数据库中各种数据项的执行单元. 事务是一条SQL语句,一组SQL语句,或者整个程序. 事务是恢复和并发控制的基本单位. ...
- mysql删除check约束_高级SQL特性——约束与索引
一.约束 1.约束的作用 对表中数据进行进一步限制,保证表中数据的完整性.一致性和正确性. 2.约束的分类 1)主键约束 主键能够唯一地标识表中的一行,比如学生表中的学生id. 它的主要作用就是能够将 ...
- MySQL 非空约束(NOT NULL)入门
MySQL 非空约束(NOT NULL)指字段的值不能为空.对于使用了非空约束的字段,如果用户在添加数据时没有指定值,数据库系统就会报错.可以通过 CREATE TABLE 或 ALTER TABLE ...
- MySQL主键约束(PRIMARY KEY ,PK)
MySQL主键约束(PRIMARY KEY ,PK) 在数据库中使用过程中 如果 想将某个字段作为唯一标识,标记所有内容时,则可以使用PK 约束进行设置.即PK约束在创建数据库表时为某些字段加上&qu ...
最新文章
- 求和(dfs序+线段树)
- 科技公司升职的谎言与真相
- 面试:为什么 https 比 http 更安全?
- java调用easyxml接口_【技术教程】如何通过Java程序调用RTSP拉流协议视频平台EasyNVR程序接口?...
- Python线程、进程、进程池、协程
- android手机编译可运行的linux程序
- 计算任意两个圆的交点
- firewall cmd mysql_centos的firewall-cmd使用手册
- 修改UCenter用户名长度限制的方法php程序和数据库修改
- SQL面试经典题(含答案)
- python tensorflow 以图搜图_以图搜图系统工程实践
- matlab 函数定义 属性,matlab class()函数类定义技巧
- 【译】可扩展前端2  —  常见模式
- PSRAM 伪静态随机存取内存
- mfc键盘控制移动鼠标光标_如何在Windows中使用键盘控制鼠标光标
- 会解方程会画图的超级计算器
- 用户标签体系的搭建方法
- python实现电子邮件附件指定时间段,批量下载以及C#小程序集成实现
- 学习心得flatten函数
- 2022年互联网直播行业研究报告