【MySQL】表的约束——空属性、默认值、列描述、zerofill、主键、自增长、唯一键、外键

文章目录

  • MySQL
  • 表的约束
    • 1. 空属性
    • 2. 默认值
    • 3. 列描述
    • 4. zerofill
    • 5. 主键
    • 6. 自增长
    • 7. 唯一键
    • 8. 外键

MySQL

在这里插入图片描述

  

表的约束

  MySQL中的表的约束是一种规则,用于限制或保护表中数据的完整性和合法性。约束可以确保数据在插入、更新或删除时满足特定的条件,从而维护数据的正确性和一致性。

1. 空属性

  两个值:null(默认的)和not null(不为空)

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

创建一个数据表其中的id1为NULL,id2为NOT NULL:

create table test1(id1 int null,id2 int not null);

在这里插入图片描述
  

查看表中的结构:

desc test1;

在这里插入图片描述

我们看到对于数据id1,是可以填写NULL值的,而id2则无法填写空值。

  

向test1插入不同的数据并且打印:

insert into test1(id1,id2) values(10,20); // 插入成功insert into test1(id2) values(20); // 插入成功,id1可以为空值insert into test1(id1) values(20); // 插入失败,id2不可以是空值
//ERROR 1364 (HY000): Field 'id2' doesn't have a default value

在这里插入图片描述

在这里插入图片描述

  所以我们在设计数据库表的时候,一定要在表中进行限制,满足上面条件的数据就不能插入到表中。这就是“约束”。

  

2. 默认值

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

  注意:not null和defalut一般不需要同时出现,因为default本身有默认值,不会为空。

创建一个表,包含不能为空的姓名,默认值为0的年龄,默认值为男的性别:

mysql> create table test2(-> name varchar(20) not null,-> age tinyint unsigned default 0,-> sex char(2) default '男'-> );

在这里插入图片描述
  

查看表中的结构:

desc test2;

在这里插入图片描述

  可以看到我们的年龄和性别都成功的设置好了默认值0和男。当我们在插入数据的时候不给该字段赋值,就使用默认值。

  

向表中插入数据并打印:

mysql> insert into test2(name,age,sex) values('张三',18,'男');
mysql> insert into test2(name,age,sex) values('小红',20,'女');
mysql> insert into test2(name,age) values('李四',22); // 只使用sex的默认值
mysql> insert into test2(name) values('王五'); // 只填了姓名,使用age和sex的默认值

在这里插入图片描述

  

3. 列描述

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

创建和上面类似的代码同时加上列描述:

mysql> create table test3(-> name varchar(20) not null comment '姓名',-> age tinyint default 0 comment '年龄',-> sex char(2) default '男' comment '性别'-> );

  

此时不能desc查看到列描述,但是可以使用show操作:

desc test3;
show create table test3\G

在这里插入图片描述

在这里插入图片描述

  

4. zerofill

  zerofill:将自动为该列的值填充前导零,以确保该列的总宽度(包括符号位,如果有的话)与列定义中指定的显示宽度相匹配,类似一种格式化输出。

创建一张表,其中int类型a使用zerofill,而int类型b不加任何约束:

mysql> create table test4(-> a int(5) zerofill,-> b int(10)-> );

在这里插入图片描述

  

查看表的结构:

desc test4;

在这里插入图片描述

  

插入数据并且打印:

mysql> insert into test4(a,b) values(1,1);
mysql> insert into test4(a,b) values(10,20);
mysql> select * from test4;

在这里插入图片描述

  

  int既然是四个字节,那是否int(10)和int(5)是一样的呢?

  其实没有zerofill这个属性,括号内的数字是毫无意义的。这个数字并不代表该列可以存储的最大整数值或存储大小。相反,这个数字是所谓的“显示宽度”(display width),它主要用于控制当查询结果返回时该列的显示宽度。

我们使用十六进制查看a的数值:

mysql> select a,hex(a) from test4;

在这里插入图片描述

  所以可以看出数据库内部存储的还是1和10,00001和00010只是设置了zerofill属性后的一种格式化输出而已。

  

5. 主键

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

创建一张表,其中包括int类型的id和varchar类型的name,其中id为主键:

mysql> create table test5(-> id int unsigned primary key,-> name varchar(20)-> );

在这里插入图片描述

  

查看表结构:

desc test5;

在这里插入图片描述

  其中id的Key就标记上了主键标志PRI。

  

向表中插入数据并且打印:

mysql> insert into test5 values(1,'张三');
mysql> insert into test5 values(2,'李四');
mysql> insert into test5 values(3,'王五');mysql> insert into test5 values(3,'赵六');
ERROR 1062 (23000): Duplicate entry '3' for key 'PRIMARY'

在这里插入图片描述

在这里插入图片描述

  我们看到了当表中有id为3的数据时,此时在插入id=3的数据时就会直接报错,这样就很好的约束了我们表中由主键标记的数据是唯一的。

  

删除主键(id):

mysql> alter table test5 drop primary key;

在这里插入图片描述

  

如果创建的表中没有主键,我们可以向某一个字段(这里向id)追加主键:

alter table test5 add primary key(id);

在这里插入图片描述

  

上面,如果追加的字段有重复的字段,就无法继续追加主键,需要删除相同的字段:

  此时的表中有重复的id。

在这里插入图片描述

  因为有重复的id,所以添加主键失败。

在这里插入图片描述

  删除重复包含的id的数据。

在这里插入图片描述

  再次插入主键成功。

在这里插入图片描述

  

6. 自增长

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

  自增长的特点:

  (1)任何一个字段要做自增长,前提是本身是一个索引(key一栏有值);

  (2)自增长字段必须是整数;

  (3)一张表最多只能有一个自增长。

  

创建一张表,其中的id为主键且自增长,name为varchar类型:

mysql> create table test6(-> id int primary key auto_increment,-> name varchar(10)-> );

在这里插入图片描述

  

查看表结构:

desc test6;

在这里插入图片描述

  

插入数据并且打印:

mysql> insert into test6 values(1,'张三');
mysql> insert into test6 values(2,'李四');
mysql> insert into test6(name) values('王五');mysql> select * from test6;

在这里插入图片描述

  可以看到我们在没有输入id的时候,自增长会帮我们自动的向最大值进行+1操作。

  

7. 唯一键

  一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题。

  唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较。

  关于唯一键和主键的区别:

  我们可以简单理解成,主键更多的是标识唯一性的。而唯一键更多的是保证在业务上,不要和别的信息出现重复。 就像我们在学校一样,我们的学号就是我们的主键是唯一标识的,而学生的手机号设置为唯一键(可能会人没有手机号的情况)。

  学号字段是主键,它保证了每个学生都有一个唯一的学号,并且学号不能为空。手机号是唯一键,它确保了在这个表中手机号的唯一性。因为我们不会使用每个人的手机号做区分的标识。主键和唯一键不冲突,相互补充。

  

创建表,其中的id为主键,phone为唯一键:

mysql> create table test7(-> id int primary key,-> phone int unique-> );

在这里插入图片描述
  

查看表结构:

desc test7;

在这里插入图片描述
  

插入数据并且打印:

mysql> insert into test7 values(1,111);
mysql> insert into test7 values(2,222);
mysql> insert into test7 values(3,333);mysql> insert into test7 values(4,333);
ERROR 1062 (23000): Duplicate entry '333' for key 'phone' // phone重复,直接报错mysql> select *from test7;

在这里插入图片描述

  

8. 外键

  外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。

在这里插入图片描述
  

创建主键表包含id和name:

create table myclass (id int primary key,name varchar(30) not null comment'班级名'
);

  

创建从表包含id,name,class_id,外连接myclass的id:

create table stu (id int primary key,name varchar(30) not null comment '学生名',class_id int,foreign key (class_id) references myclass(id)
);

在这里插入图片描述
  

查看两张表的结构:

在这里插入图片描述

  

插入数据并且打印:

mysql> insert into myclass values(10, 'C++大牛班'),(20, 'java大神班');
mysql>  insert into stu values(100, '张三', 10),(101, '李四',20);mysql> insert into stu values(102, 'wangwu',30); // 没有这个班级,插入失败
ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint fails (`constraint_test`.`stu`, CONSTRAINT `stu_ibfk_1` FOREIGN KEY (`class_id`) REFERENCES `myclass` (`id`))
mysql> select* from myclass;
mysql> select* from stu;

在这里插入图片描述
  

笛卡尔积打印两张表的组合:

mysql> select* from stu,myclass;

在这里插入图片描述
  

筛选出有关联的数据:

mysql> select* from stu,myclass where stu.class_id=myclass.id;

在这里插入图片描述

  

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/719263.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL相关问题

MySQL相关问题 一、MySQL支持哪些存储引擎?二、MySQL是如何执行一条SQL的?三、MySQL数据库InnoDB存储引擎是如何工作的?四、如果要对数据库进行优化,该怎么优化?五、MySQL如何定位慢查询?六、如何分析MySQL…

揭秘App访问量背后的秘密:数据统计与分析

在移动互联网时代,App已成为人们日常生活的重要组成部分。对于App运营者来说,了解用户的访问量、行为习惯等数据至关重要。本文将深入探讨如何精准统计App访问量,为运营者提供有价值的数据支持。 一、App访问量统计的重要性 访问量是衡量A…

计算机专业必看的十部电影

计算机专业必看的十部电影 1. 人工智能2. 黑客帝国3. 盗梦空间4. 社交网络5. Her6. 模仿游戏7. 斯诺登8. 头号玩家9. 暗网10. 网络迷踪 计算机专业必看的十部电影,就像一场精彩盛宴! 《黑客帝国》让你穿越虚拟世界,感受高科技的魅力《模仿游戏…

公网IP怎么获取?

公网IP是网络中设备的唯一标识符,用于在Internet上进行通信和定位。对于普通用户来说,了解如何获取自己的公网IP是很有必要的,本文将介绍几种获取公网IP的方法。 方法一:通过路由器查询 大多数家庭和办公室使用的路由器都会有一个…

深入解析Mybatis-Plus框架:简化Java持久层开发(七)

🍀 前言 博客地址: CSDN:https://blog.csdn.net/powerbiubiu 👋 简介 本章节介绍如何通过Mybatis-Plus删除数据库中的数据。 本章节不需要前置准备,继续使用之前的测试类,数据库表进行操作。 &#x1f4…

day03_Vue_Element

文章目录 01.Ajax1.1 Ajax 概述1.2 同步异步1.3 原生Ajax 2. Axios2.1 Axios的基本使用2.2 Axios快速入门2.3请求方法的别名2.4 案例 3 前后台分离开发3.1 前后台分离开发介绍 04 YAPI4.1 YAPI介绍4.2 接口文档管理 05 前端工程化5.1 前端工程化介绍5.2 前端工程化入门5.2.1 环…

【Python】变量的引用

🚩 WRITE IN FRONT 🚩 🔎 介绍:"謓泽"正在路上朝着"攻城狮"方向"前进四" 🔎🏅 荣誉:2021|2022年度博客之星物联网与嵌入式开发TOP5|TOP4、2021|2222年获评…

2024.3.4 作业

1、流式域套接字 1>tcp服务端实现 #include<myhead.h> int main(int argc, const char *argv[]) {//1、创建套接字int sfd socket(AF_UNIX, SOCK_STREAM, 0);if(sfd -1){perror("socket error");return -1;}//2、判断套接字文件是否存在&#xff0c;如果…

5G工业智能网关保障煤矿安全生产

随着物联网技术发展与煤矿需求的持续激增&#xff0c;矿山矿井的分布范围广泛、户外环境恶劣等管理问题急需解决&#xff0c;而物联网网关工业级设计能够无惧恶劣环境干扰&#xff0c;轻松解决户外网络部署问题。 工业网关通过采集矿井内的各类传感器数据对矿井进行远程监控&a…

【NR 定位】3GPP NR Positioning 5G定位标准解读(五)

前言 3GPP 标准网址&#xff1a;Directory Listing /ftp/ 【NR 定位】3GPP NR Positioning 5G定位标准解读&#xff08;一&#xff09;-CSDN博客 【NR 定位】3GPP NR Positioning 5G定位标准解读&#xff08;二&#xff09;-CSDN博客 【NR 定位】3GPP NR Positioning 5G定位…

[GYCTF2020]EasyThinking --不会编程的崽

看标题就知道&#xff0c;这大概率是关于thinkphp的题目。先尝试错误目录使其报错查看版本号 thinkphp v6.0.0&#xff0c;在网上搜索一下&#xff0c;这个版本有一个任意文件上传漏洞。参考以下文章。 https://blog.csdn.net/god_zzZ/article/details/104275241 先注册一个账…

VL53L8CX驱动开发(1)----驱动TOF进行区域检测

VL53L8CX驱动开发----1.驱动TOF进行区域检测 概述视频教学样品申请源码下载主要特点硬件准备技术规格系统框图应用示意图区域映射生成STM32CUBEMX选择MCU 串口配置IIC配置LPn 设置X-CUBE-TOF1串口重定向代码配置Tera Term配置演示结果 概述 VL53L8CX是一款8x8多区域ToF测距传感…

STM32(6)中断

1.中断 1.1 中断的概念 STM32的中断&#xff1a; 1.2 中断优先级 用数字的大小表示中断优先级的高低&#xff0c;数字的范围&#xff1a;0000--1111&#xff08;二进制&#xff09;&#xff0c;即0-15&#xff0c;共16级优先级。 进一步对这4位二进制数进行划分&#xff0c;可…

demo型xss初级靶场

一、环境 XSS Game - Ma Spaghet! | PwnFunction 二、开始闯关 第一关 看看代码 试一下直接写 明显进来了为什么不执行看看官方文档吧 你不执行那我就更改单标签去使用呗 ?somebody<img%20src1%20onerror"alert(1)"> 防御&#xff1a; innerText 第二关…

分账系统哪个好 盘点2024年好用的四款分账系统

分账系统在现代商业活动中扮演着至关重要的角色&#xff0c;为企业提供了高效、准确的分账管理。那么&#xff0c;你知道2024年哪几款分账系统最好用呢&#xff1f;跟着小编的脚步去看看吧&#xff01; 一、商淘云 商淘云是广州商淘信息科技有限公司旗下品牌&#xff0c;它提…

ShardingJdbc分库分表-浅谈分表原理

文章目录 为什么要分库分表一、分库分表二、不停机分库分表数据迁移 为什么要分库分表 一般的机器&#xff08;4核16G&#xff09;&#xff0c;单库的MySQL并发&#xff08;QPSTPS&#xff09;超过了2k&#xff0c;系统基本就完蛋了。最好是并发量控制在1k左右。这里就引出一个…

matplotlib从起点出发(14)_Tutorial_imshow_origin_extent

0 总述 imshow()允许你将图像&#xff08;将进行颜色映射——基于norm和cmap——的2D数组或将按原样使用的3D RGB(A)的数组&#xff09;渲染到数据空间中的矩形区域。最终渲染中图像的方向由原点和范围关键字参数&#xff08;以及生成的AxesImage实例上的属性&#xff09;和Ax…

一.数据分析简介

目录 一、了解数据分析 1.1 什么是数据分析 1.2 数据分析的重要性 1.3 数据分析的基本流程 数据获取 数据处理 1.4 数据分析的应用场景 客户分析 营销分析 二、数据分析工具 jupyter 2.1 编辑器安装 2.2 Jupyter快捷使用 一、了解数据分析 学习数据分析&#xff0…

FPGA之加法逻辑运算

由于FPGA需要被反复烧写&#xff0c;它实现组合逻辑的基本结构不可能像ASIC 那样通过固定的与非门来完成&#xff0c;而只能采用一种易于反复配置的结构。查找表可以很好地满足这一要求&#xff0c;目前主流FPGA都采用了基于SRAM 工艺的查找表结构。LUT本质上就是一个RAM。它把…

HarmonyOS-卡片页面能力说明和使用动效能力

卡片页面能力说明 开发者可以使用声明式范式开发ArkTS卡片页面。如下卡片页面由DevEco Studio模板自动生成&#xff0c;开发者可以根据自身的业务场景进行调整。 ArkTS卡片具备JS卡片的全量能力&#xff0c;并且新增了动效能力和自定义绘制的能力&#xff0c;支持声明式范式的…