MySQL数据库表约束讲解


Posted in MySQL onJune 21, 2022

MySQL数据库表约束

为了防止往数据表中插入错误的数据,在MySQL中,定义了一些维护数据库完整性的规则,即表的约束。

常见的表的约束:

MySQL数据库表约束讲解

上表中列举的约束条件都是针对表中字段进行限制, 从而保证数据表中数据的正确性和唯一性。

一、主键约束

在MySQL中,为了快速查找表中的某条信息,可以通过设置主键来实现。主键约束是通过PRIMARY KEY定义的,它可以唯一标识表中的记录,这就好比身份证可以用来标识人的身份一样。

在MySQL中,主键约束分两种,具体如下:

1、单字段主键

单字段主键指的是由一个字段构成的主键,其基本语法如下:

MySQL数据库表约束讲解

上述案例中,表student创建了id、name和grade三个字段,其中id字段是主键。

2、多字段主键

多字段主键指的是多个字段组合而成的主键,其基本的语法格式如下所示:

MySQL数据库表约束讲解

上述案例中,表student创建了id、name和grade三个字段,其中id和name两个字段组合可以唯一确定一条记录。

【补充】一个表最多可以创建一个主键。

二、外键约束

如果表A的主键是表B中的字段,则该字段称为表B的外键;另外表A称为主表,表B称为从表。外键是用来

实现参照完整性的,不同的外键约束方式将可以使两张表紧密的结合起来,特别是修改或删除的级联操作将使

得日常维护更轻松。外键主要用来保证数据的完整性和一致性。其基本语法如下:

MySQL数据库表约束讲解

【补充】一个表允许有多个外键,且外键只适用于InnoDB表,MyISAM表不支持外键。

InnoDB表和MyISAM表的主要区别是:InnoDB表支持事务、行锁和外键,MyISAM不支持;InnoDB表索引式修改效率较MyISAM高,MyISAM表查询、插入和删除效率较InnoDB高,而且MyISAM索引和数据分离,索引压缩存储,而InnoDB索引和数据紧密结合,不支持压缩,所以MyISAM内存利用率比InnoDB高;另外MyISAM的移植性也更强。

三、非空约束

非空约束指的是字段的值不能为NULL,在MySQL中,非空约束是通过NOT NULL定义的,其基本语法

如下:

MySQL数据库表约束讲解

上述案例中,表student包含id、name和grade三个字段。其中id为主键,name为非空字段。

【补充】一个表可以有多个非空约束字段。

四、唯一约束

唯一约束用于保存数据表中字段的唯一性,类似于主键,即表中字段值不能重复出现。

唯一约束是通过UNIQUE定义的,其基本语法如下:

MySQL数据库表约束讲解

上述案例中,表student包含id、name和grade三个字段。其中id为主键,name字段为唯一值,不能重复。

【补充】一个表可以有多个唯一约束字段。

五、默认约束

默认约束用于给数据表中的字段指定默认值,即当在表中插入一条新纪录时,如果没有给这个字段赋值,那么,数据库系统会自动为这个字段插入默认值。

默认值是通过DEFAULT关键字定义的,其基本语法如下:

MySQL数据库表约束讲解

上述案例中,表student包含id、name和grade三个字段。其中id为主键,grade字段的默认值为0。

【补充】一个表可以有多个默认约束字段。

六、自增约束

在数据表中,若想为表中插入新记录自动生成唯一的ID,可以使用AUTO_INCREMENT约束来实现。

AUTO_INCREMENT约束的字段可以是任何整数类型。默认情况下,改字段的值是从1开始自增的。

其基本语法如下:

MySQL数据库表约束讲解

上述案例中,表student包含id、name和grade三个字段。其中id为主键,且没插入一条新纪录,id都会自动增加。

【补充】一个表只能设置一个自增约束字段。

数据库建表的约束条件

常用约束条件及简单介绍

primary key (PK)      #标识该字段为该表的主键,可以唯一的标识记录,主键就是不为空    且唯一当然其还有加速查询的作用
foreign key (FK)      #标识该字段为该表的外键,用来建立表与表的关联关系
not null              #标识该字段不能为空
unique key (UK)       #标识该字段的值是唯一的
auto_increment        #标识该字段的值自动增长(整数类型,而且为主键)
default               #为该字段设置默认值
unsigned              #将整型设置为无符号即正数
zerofill              #不够使用0进行填充

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。           


Tags in this post...

MySQL 相关文章推荐
MySQL创建索引需要了解的
Apr 08 MySQL
Mysql基础之常见函数
Apr 22 MySQL
MySQL Router的安装部署
Apr 24 MySQL
MySQL修炼之联结与集合浅析
Oct 05 MySQL
mysql主从复制的实现步骤
Oct 24 MySQL
mysql分表之后如何平滑上线详解
Nov 01 MySQL
mysql函数全面总结
Nov 11 MySQL
浅谈MySql整型索引和字符串索引失效或隐式转换问题
Nov 20 MySQL
SQL基础查询和LINQ集成化查询
Jan 18 MySQL
一条慢SQL语句引发的改造之路
Mar 16 MySQL
优化Mysql查询的示例
Apr 26 MySQL
delete in子查询不走索引问题分析
Jul 07 MySQL
MySQL数据库实验之 触发器和存储过程
Jun 21 #MySQL
MySQL transaction事务安全示例讲解
Jun 21 #MySQL
MySQL详细讲解变量variables的用法
Jun 21 #MySQL
mysql sql常用语句大全
Jun 21 #MySQL
MySQL示例讲解数据库约束以及表的设计
Jun 16 #MySQL
mysql幻读详解实例以及解决办法
Jun 16 #MySQL
mysql数据库隔离级别详解
Jun 16 #MySQL
You might like
3
2006/10/09 PHP
PHP中基于ts与nts版本- vc6和vc9编译版本的区别详解
2013/04/26 PHP
关于php微信订阅号开发之token验证后自动发送消息给订阅号但是没有消息返回的问题
2015/12/21 PHP
Yii2框架RESTful API 格式化响应,授权认证和速率限制三部分详解
2016/11/10 PHP
Thinkphp 框架扩展之类库扩展操作详解
2020/04/23 PHP
event对象的方法 兼容多浏览器
2009/06/27 Javascript
表单JS弹出填写提示效果代码
2011/04/16 Javascript
『jQuery』取指定url格式及分割函数应用
2013/04/22 Javascript
Get中文乱码IE浏览器Get中文乱码解决方案
2013/12/26 Javascript
详解vue父子组件关于模态框状态的绑定方案
2019/06/05 Javascript
使用localStorage替代cookie做本地存储
2019/09/25 Javascript
在VUE中实现文件下载并判断状态的方法
2019/11/08 Javascript
vue+webpack dev本地调试全局样式引用失效的解决方案
2019/11/12 Javascript
微信小程序获取复选框全选反选选中的值(实例代码)
2019/12/17 Javascript
vue在响应头response中获取自定义headers操作
2020/07/24 Javascript
vue mvvm数据响应实现
2020/11/11 Javascript
小程序实现上下切换位置
2020/11/16 Javascript
python中查找excel某一列的重复数据 剔除之后打印
2013/02/10 Python
selenium+python自动化测试之环境搭建
2019/01/23 Python
python求平均数、方差、中位数的例子
2019/08/22 Python
Python面向对象编程基础实例分析
2020/01/17 Python
python用WxPython库实现无边框窗体和透明窗体实现方法详解
2020/02/21 Python
pycharm设置默认的UTF-8编码模式的方法详解
2020/06/01 Python
Keras 在fit_generator训练方式中加入图像random_crop操作
2020/07/03 Python
使用Html5 Stream开发实时监控系统
2020/06/02 HTML / CSS
iRobot官网:改变生活的家用机器人品牌
2016/09/20 全球购物
Berghaus官网:户外服装和设备,防水服
2020/01/17 全球购物
入党积极分子学习两会心得体会范文
2014/03/17 职场文书
孝敬父母的活动方案
2014/08/31 职场文书
高中升旗仪式演讲稿
2014/09/09 职场文书
大学生个人简历自荐信
2015/03/06 职场文书
Python import模块的缓存问题解决方案
2021/06/02 Python
Pytest中skip和skipif的具体使用方法
2021/06/30 Python
三种方式清除vue路由跳转router-link的历史记录
2022/04/10 Vue.js
二维码条形码生成的JavaScript脚本库
2022/07/07 Javascript
Go gorilla/sessions库安装使用
2022/08/14 Golang