当前位置: 首页 > news >正文

MySQL:表的约束(上)

文章目录

  • 空属性
  • 默认值
  • 列描述
  • zerofill
  • 主键

本篇总结的是MySQL中关于表的约束部分的内容

空属性

在进行表的创建时,会有两个值,null和not null,而数据库默认的字段基本都是空,但是在实际的开发过程中要保证字段不能为空,因为数据为空就意味着不能进行参与运算

mysql> select null;
+------+
| NULL |
+------+
| NULL |
+------+
1 row in set (0.00 sec)mysql> select 1+null;
+--------+
| 1+null |
+--------+
|   NULL |
+--------+
1 row in set (0.00 sec)

如上所示,数据为空时不能进行运算的

比如,当创建一个班级表,这个表中包含的信息有班级名和班级所在的教室的时候,如果站在一个正常的业务逻辑的角度来讲,班级没有名字就不知道是哪个班级,教室没有名字就不知道在哪上课,于是在进行设计的时候,要对于表进行限制,使得只有满足这个条件才能插入到数据表中,这就是所谓的约束

我们创建一个这样的MySQL数据库:

mysql> create table myclass( class_name varchar(20) not null, class_room varchar(10) not null );
Query OK, 0 rows affected (0.07 sec)mysql> desc myclass-> ;
+------------+-------------+------+-----+---------+-------+
| Field      | Type        | Null | Key | Default | Extra |
+------------+-------------+------+-----+---------+-------+
| class_name | varchar(20) | NO   |     | NULL    |       |
| class_room | varchar(10) | NO   |     | NULL    |       |
+------------+-------------+------+-----+---------+-------+
2 rows in set (0.01 sec)

这样,就对于元素添加了限制的字样,自此之后,如果想要添加数据就必须要填写名字和教室了,如果不填写是不可以插入进去的:

mysql> insert into myclass (class_name) values ('yuwen');
ERROR 1364 (HY000): Field 'class_room' doesn't have a default value
mysql> insert into myclass (class_room) values ('class1');
ERROR 1364 (HY000): Field 'class_name' doesn't have a default value
mysql> insert into myclass (class_name, class_room) values ('yuwen', 'class1');
Query OK, 1 row affected (0.01 sec)

默认值

下一个约束是默认值,默认值的意思是,对于某一种数据会经常性的出现某个具体的值,就可以在一开始就指定好,之后在插入数据的时候如果没有需要就用默认值,需要就插入正常值

比如在程序员统计的时候,大多数程序员都是男性,所以在统计性别的时候可以默认选择男性,如果有女性的信息也没关系,可以直接插入,具体如下所示:

mysql> create table info (-> name varchar(20) not null,-> age tinyint unsigned default 0,-> sex char(2) default '男'-> );
Query OK, 0 rows affected (0.11 sec)mysql> desc info;
+-------+------------------+------+-----+---------+-------+
| Field | Type             | Null | Key | Default | Extra |
+-------+------------------+------+-----+---------+-------+
| name  | varchar(20)      | NO   |     | NULL    |       |
| age   | tinyint unsigned | YES  |     | 0       |       |
| sex   | char(2)          | YES  |     ||       |
+-------+------------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

如上所示,创建了一个人的信息表,其中包含有名字,年龄,性别,其中名字不可以忽略,而年龄和性别都设置了缺省值

所以,在插入数据的时候,对于默认值可以选择插入也可以选择不插入:

mysql> insert into info (name, age, sex) values('小明', 15, '男');
Query OK, 1 row affected (0.01 sec)mysql> insert into info (name, age) values('小亮', 16);
Query OK, 1 row affected (0.00 sec)mysql> insert into info (name) values('小宏');
Query OK, 1 row affected (0.01 sec)mysql> insert into info (name, sex) values('小红', '女');
Query OK, 1 row affected (0.00 sec)mysql> select * from info;
+--------+------+------+
| name   | age  | sex  |
+--------+------+------+
| 小明   |   15 ||
| 小亮   |   16 ||
| 小宏   |    0 ||
| 小红   |    0 ||
+--------+------+------+
4 rows in set (0.00 sec)

由此可以看出,默认值其实是生效了的

列描述

下一个介绍的约束项是列描述,它的意思就是用来描述一个字段,用来给程序员看的,比如:

mysql> create table commentinfo(-> name varchar(20) comment '要写入的是姓名',-> sex char(2) comment '要写入的是性别'-> );
Query OK, 0 rows affected (0.04 sec)

此时,如果直接进行desc是看不到这个表的信息的,但是如果选择的是show create table就可以看到了:

mysql> desc commentinfo;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| name  | varchar(20) | YES  |     | NULL    |       |
| sex   | char(2)     | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)mysql> show create table commentinfo\G
*************************** 1. row ***************************Table: commentinfo
Create Table: CREATE TABLE `commentinfo` (`name` varchar(20) DEFAULT NULL COMMENT '要写入的是姓名',`sex` char(2) DEFAULT NULL COMMENT '要写入的是性别'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
1 row in set (0.00 sec)

zerofill

下一个要介绍的约束项是,zerofill,比如在创建一个数据类型的时候可能填写的是int(10):

mysql> create table t1 (-> lenth int(10)-> );
Query OK, 0 rows affected, 1 warning (0.04 sec)mysql> desc t1;
+-------+------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+------+------+-----+---------+-------+
| lenth | int  | YES  |     | NULL    |       |
+-------+------+------+-----+---------+-------+
1 row in set (0.00 sec)

那么这个10是什么意思呢?而这个10其实是和zerofill关系起来的,我们给这个lenth这一列添加上zerofill的关键字设置:

mysql> alter table t1 change lenth lenth int(5) unsigned zerofill;
Query OK, 0 rows affected, 2 warnings (0.09 sec)
Records: 0  Duplicates: 0  Warnings: 2

此时插入信息进行查看,就会发现这个现象:

mysql> insert into t1 (lenth) values (1);
Query OK, 1 row affected (0.01 sec)mysql> select *from t1;
+-------+
| lenth |
+-------+
| 00001 |
+-------+
1 row in set (0.00 sec)

可以看到,本来应该存储的是1,现在变成了00001,这个就是zerofill属性的作用,如果宽度小于设定的宽度,那么就自动填充0,但是实际在存储的时候还是存储的是1,只是进行了一个格式化的输出而已

主键

主键表示的是标识字段里面的数据,不能重复,不能为空,一个表中最多只能有一个主键,主键所在的列通常是整数类型

mysql> create table t2 (-> id int unsigned primary key comment '学号不能重复',-> name varchar(20) not null);
Query OK, 0 rows affected (0.03 sec)mysql> desc t2;
+-------+--------------+------+-----+---------+-------+
| Field | Type         | Null | Key | Default | Extra |
+-------+--------------+------+-----+---------+-------+
| id    | int unsigned | NO   | PRI | NULL    |       |
| name  | varchar(20)  | NO   |     | NULL    |       |
+-------+--------------+------+-----+---------+-------+
2 rows in set (0.01 sec)

这样就创建了主键,下面进行插入数据:

mysql> insert into t2 (id, name) values(123, '小明');
Query OK, 1 row affected (0.00 sec)mysql> insert into t2 (id, name) values(123, '小红');
ERROR 1062 (23000): Duplicate entry '123' for key 't2.PRIMARY'

当插入两个相同id的信息时,就会报错,这说明id是不可以被重复的,因为它是主键

这里需要注意的是,主键只有一个,并不意味着只能给一列添加主键,还存在一个复合主键,可以给多个列添加,这写列合起来作为主键

相关文章:

MySQL:表的约束(上)

文章目录 空属性默认值列描述zerofill主键 本篇总结的是MySQL中关于表的约束部分的内容 空属性 在进行表的创建时,会有两个值,null和not null,而数据库默认的字段基本都是空,但是在实际的开发过程中要保证字段不能为空&#xff…...

树莓派5使用体验

原文地址:树莓派5使用体验 - Pleasure的博客 下面是正文内容: 前言 好久没有关于教程方面的博文了,由于最近打算入门嵌入式系统,所以就去购入了树莓派5开发板 树莓派5是2023年10月23日正式发售的,过去的时间不算太远吧…...

代码随想录算法训练营第42天| 背包问题、416. 分割等和子集

01 背包 题目描述:有n件物品和一个最多能背重量为w 的背包。第i件物品的重量是weight[i],得到的价值是value[i] 。每件物品只能用一次,求解将哪些物品装入背包里物品价值总和最大。 二维dp数组01背包: 确定dp数组以及下标的含义 …...

Node.js安装及环境配置指南

Node.js安装及环境配置指南 一、Node.js的安装 安装Node.js之前,首先需要确保你的电脑已经安装了合适的编译器和开发环境。Node.js是一个开源的、跨平台的JavaScript运行环境,它使得JavaScript可以在服务器端运行。 下载Node.js安装包 访问Node.js的…...

【Java基础】面试题汇总

Java基础面试题1. JVM vs JDK vs JRE 2. 什么是字节码?采用字节码的好处是什么?3. 为什么说 Java 语言“编译与解释并存”?4. AOT 有什么优点?为什么不全部使用 AOT 呢?5. Java 和 C 的区别?6. Java 中的基本数据类型&#xff1…...

数据库事务的超级详细讲解,包括事务特性、事务隔离级别、MVCC(多版本并发控制)

数据库事务: 主要有事务特性,事务的隔离级别,MVCC。 事务特性: 事务(Transaction)是指作为单个逻辑工作单元执行的一系列操作,这些操作要么全部成功执行,要么全部不执行&#xff…...

鸿蒙Lottie动画-实现控制动画的播放、暂停、倍速播放、播放顺序

介绍 本示例展示了lottie对动画的操作功能。引入Lottie模块,实现控制动画的播放、暂停、倍速播放、播放顺序、播放到指定帧停止或从指定帧开始播放、侦听事件等功能,动画资源路径必须是json格式。 效果预览 使用说明: 进入页面默认开始201…...

C++面试100问与自动驾驶100问

C的学习和面试其实是非常的不友好的,首先C的学习内容非常的多,其次C的面试不单单面试C的知识点,还有它的“七大姑八大姨”(计算机网络、数据结构、算法、计算机组成原理、操作系统、编译、xxx的底层实现 and so on)。 …...

加速 Redis 操作:掌握管道技术提升性能与效率

Redis 管道技术是一种用于优化 Redis 命令执行效率的机制。在传统的 Redis 操作中,每次向 Redis 服务器发送一个命令,都需要等待命令执行完成并返回结果,这样会导致频繁的网络通信和服务器端的命令执行开销,降低系统的性能和吞吐量…...

深入浅出 -- 系统架构之分布式系统底层的一致性

在分布式领域里,一致性成为了炙手可热的名词,缓存、数据库、消息中间件、文件系统、业务系统……,各类分布式场景中都有它的身影,因此,想要更好的理解分布式系统,必须要理解“一致性”这个概念。 其实关于…...

idea Springboot 电影推荐系统LayUI框架开发协同过滤算法web结构java编程计算机网页

一、源码特点 springboot 电影推荐系统是一套完善的完整信息系统,结合mvc框架和LayUI框架完成本系统springboot dao bean 采用协同过滤算法进行推荐 ,对理解JSP java编程开发语言有帮助系统采用springboot框架(MVC模式开发)&…...

xss【2】

1.xss钓鱼 钓鱼攻击利用页面,fish.php黑客钓鱼获取到账号密码存储的位置 xss进行键盘记录 2.xss常规防范 3.xss验证payload XSS(跨站攻击)_details/open/ontoggle-CSDN博客...

时序分解 | Matlab实现GSWOA-VMD改进鲸鱼优化算法优化变分模态分解时间序列信号分解

时序分解 | Matlab实现GWO-CEEMDAN基于灰狼算法优化CEEMDAN时间序列信号分解 目录 时序分解 | Matlab实现GWO-CEEMDAN基于灰狼算法优化CEEMDAN时间序列信号分解效果一览基本介绍程序设计参考资料 效果一览 基本介绍 Matlab实现GSWOA-VMD改进鲸鱼优化算法优化变分模态分解时间序…...

css- 4

1.浮动 1. 浮动最初用于实现文字环绕效果 2. 现在,浮动是主流的布局方式之一 1.1元素浮动之后的特点 元素浮动之后,称为浮动元素,具有如下特点: 1. 浮动元素脱离文档流 2. 多个浮动的元素会水平排列,一行放不下自动换…...

22.括号生成

题目描述 数字 n 代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 有效的 括号组合。 示例 1: 输入:n 3 输出:[“((()))”,“(()())”,“(())()”,“()(())”,“()()()”] 示例 2: 输入…...

JAVA八股--redis

JAVA八股--redis 如何保证Redis和数据库数据一致性redisson实现的分布式锁的主从一致性Redis脑裂现象及解决方案介绍I/O多路复用模型undo log 和 redo log(没掌握MyISAM 和 InnoDB 有什么区别? 如何保证Redis和数据库数据一致性 关于异步通知中消息队列…...

[图像处理] MFC载入图片并绘制ROI矩形

上一篇: [图像处理] MFC载入图片并进行二值化处理和灰度处理及其效果显示 文章目录 前言完整代码重要代码效果 前言 上一篇实现了MFC通过Picture控件载入图片。 这一篇实现ROI功能的第一部分,在Picture控件中,通过鼠标拖拽画出一个矩形。 完…...

Godot 4 教程《勇者传说》依赖注入 学习笔记(0):环境配置

文章目录 前言相关地址环境配置初始化环境配置文件夹结构代码结构代码运行 资源文件导入像素风格窗口环境设置背景设置,Tileap使用自动TileMap 人物场景动画节点添加站立节点添加移动动画添加 通过依赖注入获取Godot的全局属性项目声明 当前项目逻辑讲解角色下降添加代码位置问…...

强行让Java和Go对比一波[持续更新]

概述 很多Java开发如果想转Golang的话,比较让Java开发蛋疼的第一是语法,第二是一些思想和设计哲学的Gap,所以我这儿强行整理一波Java和Golang的对比,但是由于GO和Java在很多方面都有不同的设计,所以这些对比的项可以更…...

理解七层网络协议

osi体系结构 上三路(管数据) 应用层 通过http等,把传输的格式,数据打包 处理网络应用。直接为端用户服务,提供各类应用过程的接口和用户接口。例如:HTTP、Tenlent、FTP、SMTP、NFS等。基于TCP的FTP、HTTP…...

网络协议——HTTP协议

目录 ​编辑 一,HTTP协议基本认识 二,认识URL 三,http协议的格式 1,发送格式 2,回应格式 四,服务端代码 五,http报文细节 1,Post与Get方法 2,Content_lenth 3&…...

八股面试——数据库——索引

索引的概念 B树的概念: 索引的作用 聚簇索引与非聚簇索引 聚簇索引就是主键值,在B树上,通过主键大小(数据在B树叶子节点按主键顺序排序)寻找对应的叶子节点,叶子节点保存的一整条记录。 非聚簇索引&#x…...

【二分查找】Leetcode 二分查找

题目解析 二分查找在数组有序可以使用,也可以在数组无序的时候使用(只要数组中的一些规律适用于二分即可) 704. 二分查找 算法讲解 当left > right的时候,我们循环结束,但是当left和right缩成一个点的时候&#x…...

Python+Vuecil笔记

Nginx 进入目录: C:\nginx-1.20.2\nginx-1.20.2 start nginx 开始 nginx -s stop 停止 nginx -s quit 退出CSS 通过标签去写css 循环展示数据 JS 点击时执行事件 Django 配置media 在seetings里面修改 STATIC_URL /static/ MEDIA_URL /upload/ MEDIA_ROOT os.pat…...

C语言关于随机数知识点的总结

在C语言中&#xff0c;随机数的生成通常依赖于特定的库函数&#xff0c;最常用的是 <stdlib.h> 头文件中的 rand() 函数。以下是对随机数知识点的总结、举例和分析&#xff1a; 随机数知识点总结 1.随机数种子&#xff1a;rand() 函数生成的随机数是伪随机数&#xff0…...

网络应用层和传输层

网络中有很多协议这些协议的不同导致了分层这一现象&#xff0c;不同层的主要功能不一样。 应用层&#xff1a;应用程序。数据具体如何使用 传输层&#xff1a;关注起点和终点 网络层&#xff1a;关注路径规划 数据链路层&#xff1a;关注相邻节点的转发 物理层&#xff1…...

Vue3:优化-从响应式数据中获取纯数据

一、情景说明 我们知道&#xff0c;Vue3中&#xff0c;创建变量时&#xff0c;常用ref、reactive来包裹&#xff0c;这样&#xff0c;这个变量就是响应式数据 然而&#xff0c;有时候&#xff0c;我们只需要纯数据 例如&#xff0c;我们在调用后端接口的时候&#xff0c;我们只…...

C#.手术麻醉系统源码 手麻系统如何与医院信息系统进行集成?

C#.手术麻醉系统源码 手麻系统如何与医院信息系统进行集成&#xff1f; 手术麻醉系统与医院信息系统的集成是一个关键步骤&#xff0c;它有助于实现信息的共享和流程的协同&#xff0c;从而提高医疗服务的效率和质量。手麻系统与lis、his、pacs等系统的对接是医院信息化建设的重…...

学习CSS Flexbox 玩flexboxfroggy flexboxfroggy1-24关详解

欢迎来到Flexbox Froggy&#xff0c;这是一个通过编写CSS代码来帮助Froggy和朋友的游戏! justify-content 和 align-items 是两个用于控制 CSS Flexbox 布局的属性。 justify-content&#xff1a;该属性用于控制 Flexbox 容器中子项目在主轴&#xff08;水平方向&#xff09;…...

springboot项目如何配置跨域?

在Spring Boot项目中配置跨域&#xff08;CORS&#xff0c;Cross-Origin Resource Sharing&#xff09;主要是为了允许来自不同源&#xff08;不同的协议、域名或端口&#xff09;的前端应用能够访问后端API。Spring Boot提供了多种方式来配置跨域支持。 1. 使用CrossOrigin注…...

做网站带吗/企业管理软件

PCB封装的绘制经常会让一些刚入门的工程师们感到头疼&#xff0c;特别是使用Allegro软件绘制PCB封装又比其它EDA软件相对要复杂一些&#xff0c;步骤更多一些。本文&#xff0c;板儿妹和大家分享通过Allegro绘制PCB封装的详细步骤&#xff0c;包括贴片类型封装和插件类型封装。…...

wordpress divi布局/营销型网站建设费用

早先我写了一篇《函数式接口》&#xff0c;探讨了Java8中函数式接口的用法。如果你正在浏览Java8的API&#xff0c;你会发现java.util.function中 Function, Supplier, Consumer, Predicate和其他函数式接口广泛用在支持lambda表达式的API中。这些接口有一个抽象方法&#xff0…...

基础网站建设公司/合肥网站建设公司

北大计算机科学技术研究所ICST 参加SEWM2005评测报告 北京大学计算机科学技术研究所 路 斌 内容提纲 CWT100G数据预处理 Web检索 文本检索 链接分析 任务处理 Web Page分类 未来工作 CWT100G数据的预处理 URL消重 提取552.6万条可用数据 提取内容&#xff1a; 网页信息 超链接关…...

网站开发工程师任职要求/怎么提交网址让百度收录

—— “Hala, AbandonZHANG&#xff01;”~ ------------------------------------------------------------- ◊线性DP&#xff1a; 经典DP原型系列&#xff1a; NOIP 1999 拦截导弹 &#xff08;最长下降子序列入门&#xff09; 思路&#xff1a;比较简单&#xff0c;第一问…...

网络推广方案总结/北京百度seo

maven应用 测试maven应用能否使用&#xff08;可使用cmd 指令 mvn -v如果出现maven版本代表maven配置成功&#xff09;在maven内部集成了很多插件 如jdk tomcat等。。。jdk默认版本是1.5&#xff0c;tomcat默认版本事6.0真实使用时需要手动配置&#xff0c;jdk为1.8/1.7 tomca…...

阿里巴巴1688官网登录/杭州网站优化公司哪家好

vue运行为v-on在监听键盘事件时&#xff0c;添加了特殊的键盘修饰符&#xff1a;<input v-on:keyup.13"submit">vue还非常贴心地给出了常用按键的别名&#xff0c;这样就不必去记keyCode ~ ~上面代码&#xff0c;还可以在这样写&#xff1a;<input v-on:key…...