【Hello mysql】 mysql的约束(上)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 【Hello mysql】 mysql的约束

表的约束

为什么要有约束?

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

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

真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合

法性,从业务逻辑角度保证数据的正确性。比如有一个字段是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)

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8天前
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
5月前
|
关系型数据库 MySQL
MYSQL-多表操作-外键约束
MYSQL-多表操作-外键约束
|
1月前
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
34 4
|
2月前
|
SQL 关系型数据库 MySQL
MySQL中外键的使用及外键约束策略
这篇文章讨论了MySQL中使用外键的重要性,包括外键的概念、不使用外键可能导致的问题、如何设置外键约束以及不同的外键约束策略(如CASCADE和SET NULL),并通过示例演示了这些概念。
MySQL中外键的使用及外键约束策略
|
2月前
|
存储 关系型数据库 MySQL
MySQL数据库基础:约束
约束是对数据库表中字段施加的规则,确保数据的正确性、有效性和完整性。主要分为非空约束、唯一约束、默认约束、主键约束和外键约束。非空约束禁止字段值为null;唯一约束确保字段值唯一,允许null值重复;默认约束设定默认值;主键约束结合非空与唯一约束,并可设为自增型;外键约束则通过关联其他表的主键,保证数据一致性。检查约束确保字段值满足特定条件。
45 1
|
3月前
|
数据采集 关系型数据库 MySQL
在 MySQL 中使用约束
【8月更文挑战第11天】
58 0
在 MySQL 中使用约束
|
5月前
|
SQL 关系型数据库 MySQL
MySQL----约束
MySQL----约束
34 1
|
5月前
|
数据采集 关系型数据库 MySQL
MySQL数据库基础第三篇(约束)
MySQL数据库基础第三篇(约束)
|
5月前
|
存储 关系型数据库 MySQL
【MySQL技术内幕】4.6-约束
【MySQL技术内幕】4.6-约束
44 1
|
5月前
|
SQL 关系型数据库 MySQL
MySQL外键约束行为解析:CASCADE, NO ACTION, RESTRICT, SET NULL
MySQL外键约束行为解析:CASCADE, NO ACTION, RESTRICT, SET NULL
276 0