【Hello mysql】 mysql的约束

这篇具有很好参考价值的文章主要介绍了【Hello mysql】 mysql的约束。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Mysql专栏:@Mysql
本篇博客简介:介绍mysql的约束

表的约束

为什么要有约束?

我们在收集一些数据的时候会要求该数据必须存在

比如说像是国家在登记公民信息的时候身份证一栏是必须要填写的不能为空

真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合
法性,从业务逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的

表的约束很多,这里主要介绍如下几个: null/not null,default, comment, zerofill,primary
key,auto_increment,unique key 。

空属性

数据库默认字段基本都是字段为空,但是实际开发时,尽可能保证字段不为空,因为数据为空没办法参与运算

所以说对于一些属性我们要设置为非空

语法

not null

实例

我们这里创建一个班级表 其中包含班级名和所在的教室

在外面正常的逻辑中 班级和教室都是不能为空的

  • 如果班级名为空我们就不知道自己在哪个班
  • 如果教室为空我们就不知道自己在哪个教室

所以说我们在设计数据表的时候加上非空约束

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

默认值

默认值:某一种数据会经常性的出现某个具体的值,可以在一开始就指定好,在需要真实数据的时候,
用户可以选择性的使用默认值。

语法

default xxx

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

我们插入一个数据尝试

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

我们这里只插入了值zhangsna但是age和sex都自动填写了

有了default之后还需要设置非空嘛?

不需要 因为如果我们没有填值的话 系统会给我们填上默认值 所以说就不存在空值的情况了

列描述

列描述:comment,没有实际含义,专门用来描述字段,会根据表创建语句保存,用来给程序员或DBA来进行了解。

语法

comment ‘xxx’

此外我们可以通过查看创建语句来看到对于每个列的描述

实例

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

zerofill

刚开始学习数据库时,很多人对数字类型后面的长度很迷茫

比如说在下图中 int类型后面的11是什么意思呢?

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

整型不是4字节码?这个10又代表什么呢?其实没有zerofill这个属性,括号内的数字是毫无意义的

此时我们修改t8中age类型的属性 在后面加上zerofill

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

此时我们发现age的18前面补上了三个0

也就是说zerofill的意义其实是看该类型有没有达到指定的位数 如果没有达到就在前面加上0填充

主键

主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;主键所在的列通常是整数类型。

语法

primary key

实例

我们创建一张表 id作为主键 name作为非空列

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

主键约束

主键中的值不能重复 一旦重复就会报错 下面是示例

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

我们可以看到插入重复id时sql直接报错了

删除主键

语法

alter table 表名 drop primary key;

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

添加主键

语法

alter table 表名 add primary key(字段列表)

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

复合主键

在创建表的时候,在所有字段之后,使用primary key(主键字段列表)来创建主键,如果有多个字段
作为主键,可以使用复合主键

比如说在创建学生的课程表的时候学生id和课程号都是可以重复的 但是学生id和课程号的组合确是不能重复的 所以说我们要将他们设置为复合主键

语法

primary key(xxx , yyy)

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

自增长

auto_increment:当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值+1操作,得到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。

自增长的特点:

  • 任何一个字段要做自增长,前提是本身是一个索引(key一栏有值)
  • 自增长字段必须是整数
  • 一张表最多只能有一个自增长

关于索引是什么概念 我们后面的博客会讲解

语法:

auto_increment

下面是实例

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

我们开始插入名字 之后查看id的变化情况

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

我们发现id数据是从1开始依次往后递增

那么如果我们现在插入一个id为1000的数据之后的id会如何变化呢?

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

我们可以发现后面的id从1001开始自增了

唯一键

在了解唯一键之前我们首先要明白一个概念

并不是因为我们选择一个属性成为了主键这个属性才具有了唯一性 而是我们选择了一个具有唯一性的属性成为了主键

也就是说除了主键之间还有很多数据也可能具有唯一性 这也就是我们唯一键出现的原因

语法

unique

下面是实例

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

当一个数据成为唯一键之后那么这个数据就不能重复了

外键

外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。

当定义外键后,要求外键列数据必须在主表的主键列存在或为null

我们先来看最后一句加粗的话 也就是说主表中必须有数据从表中才能插入数据

语法:

foreign key (class_id) references myclass(id)

下面是实例 我们先创建主表 之后再从表中创建外键约束

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

我们首先像从表中插入数据尝试

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

我们可以发现主表中如果没有插入数据从表中是不能插入的

【Hello mysql】 mysql的约束,Mysql,mysql,数据库

而主表中有数据 从表中就可以插入数据了

【Hello mysql】 mysql的约束,Mysql,mysql,数据库
而我们删除数据的时候必须要先删除从表中的数据才能删除主表

这里总结下

  • 外键是在从表中定义的
  • 从表添加数据必须主表先添加
  • 主表删除数据必须从表先删除

我们如何理解外键约束

首先这是一种约束 它肯定是为了防止我们做出错误或不符合逻辑的操作的

理论上,上面的例子,我们不创建外键约束,就正常建立学生表,以及班级表,该有的字段我们都有。

但是实际过程中由于可能会由于人为操作的失误而造成一些错误 比如说一些数据只有学生表中有 而不存在于班级表中(这样就不知道这个学生在哪个班了)

所以说我们添加外键约束是必须的 它的本质其实就是将插入和删除数据的合法性交给mysql去审核

总结

【Hello mysql】 mysql的约束,Mysql,mysql,数据库文章来源地址https://www.toymoban.com/news/detail-540058.html

到了这里,关于【Hello mysql】 mysql的约束的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySQL数据库,数据的约束

    目录 1.数据的约束 1.1约束的类型 1.2NULL约束 1.3UNIQUE约束 1.4DEFAULT约束 1.5PRIMARY KEY约束 1.6FOREIGN KEY约束 首先,创建一个名为test的数据库: 下方的所有测试表,都是在这个test数据库中进行创建的。 NOT NULL - 指定某列不得为NULL(空) UNIQUE - 唯一值,每一列的值都是不同的 DEFAULT -

    2023年04月20日
    浏览(52)
  • 【MySQL】数据库的约束

    哈喽,大家好!我是保护小周ღ,本期为大家带来的是 MySQL 数据库中对表的约束, 主要有null (空约束),unique(唯一约束),primary key(主键约束),default(默认值约束), forelgn key(外键约束),check(检查约束),超多实例讲解,通俗易懂。 更多相关知识敬请期待:保护小周ღ *★,°*:

    2023年04月09日
    浏览(50)
  • MySQL:数据库的约束

    目录 1.数据库约束 1.1 非空:not null 1.2 唯一:unique         ​​​​​​​ 1.3 默认值:default 1.4 列描述:comment 1.5 主键约束:primary key 1.6 外键约束 1.7 综合案例 2.插入查询结果 3.聚合函数 4.group by(分组查询) 关系型数据库的一个重要功能,就是需要保证数据的完整性

    2024年02月05日
    浏览(87)
  • MySQL数据库 12:约束

    在MySQL中, 约束是一种限制数据表中列值的规定 。保证数据库中的数据正确,有效性和完整性。MySQL中的约束有以下几种: 1. 主键约束(Primary Key Constraint) :主键是用于唯一标识表中每行记录的列。主键约束要求 每个主键列的值都是唯一的,且不能为NULL 。一个表只能有一

    2024年02月08日
    浏览(47)
  • 【MySQL数据库 | 第十二篇】:约束

    在MySQL中, 约束是一种限制数据表中列值的规定 。保证数据库中的数据正确,有效性和完整性。MySQL中的约束有以下几种: 1. 主键约束(Primary Key Constraint) :主键是用于唯一标识表中每行记录的列。主键约束要求 每个主键列的值都是唯一的,且不能为NULL 。一个表只能有一

    2024年02月08日
    浏览(45)
  • MySQL数据库:数据库的约束以及数据的聚合、联合查询

    目录 一.关系模型的简要概述 二.数据库的约束  2.1约束类型         2.2NULL约束 2.3 UNIQUE:唯一约束 2.4 默认约束 2.5 PRIMARY KEY:主键约束 2.6 FOREIGN KEY:外键约束 2.7 CHECK约束 三.高效率查询 3.1高效率查询的分类 3.2聚合查询 3.2.1聚合函数 3.2.2 GROUP BY子句 3.2.3HAVING 3.3.联合查询

    2024年02月10日
    浏览(62)
  • MySQL数据库基础(九):SQL约束

    文章目录 SQL约束 一、主键约束 二、非空约束 三、唯一约束 四、默认值约束 五、外键约束(了解) 六、总结 PRIMARY KEY 约束唯一标识数据库表中的每条记录。 主键必须包含唯一的值。 主键列不能包含 NULL 值。 每个表都应该有一个主键,并且每个表只能有一个主键。 遵循原

    2024年02月19日
    浏览(56)
  • 【数据库】MySQL数据约束和表关系详解

    目录 1.数据库约束 1.1约束类型 1.2NULL约束 1.3UNIQUE:唯一约束 1.4DEFAULT:默认值约束 1.5PRIMARY:主键约束 1.6FOREIGH KEY:外键约束 2.表的关系 2.1一对一 2.2一对多 2.3多对多 数据库中的数据保存在数据表中,在表中为了更加准确的存储数据,保证数据的正确有效,可以在创建表的时候

    2024年02月04日
    浏览(45)
  • 【MySQL】一文带你了解数据库约束

    作用: 数据库约束是用于限制数据输入或数据更新的规则。数据库约束确保在表中只能插入符合规则的数据,以确保数据的完整性和一致性。 常见的数据库约束包括: 主键约束:用于唯一标识表中的每一行数据,确保数据唯一性和完整性。 外键约束:用于确保表之间数据的

    2024年02月08日
    浏览(71)
  • MySQL的约束类型、数据库操作、数据表操作大全(简述)

    目录 一.数据库的操作语法 二.MySQL数据库约束 三.数据类型 四.数据表操作 作者简介:  tq02,一个想成为编程高手的梦中人 作者主页:  tq02的博客_CSDN博客-C语言,Java,Java数据结构领域博主 学习专栏:  🎥  MySQL基础          🎥  JavaSE                🎥   C语言 本

    2024年02月12日
    浏览(87)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包