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

news2024/10/2 8:34:48

文章目录

  • 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.coloradmin.cn/o/1484575.html

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

相关文章

【C++】核心编程--类与对象(持续更新)

文章目录 1. 封装1.1封装的意义1.1.1封装意义一:属性和行为1.1.2封装的意义二:访问权限 1.2 struct和class的区别1.3 成员属性设置为私有 2.对象特性2.1 构造函数和析构函数2.2构造函数的分类及调用2.3 拷贝构造函数调用时机2.4 构造函数调用规则2.5深拷…

Flink基本原理 + WebUI说明 + 常见问题分析

Flink 概述 Flink 是一个用于进行大规模数据处理的开源框架,它提供了一个流式的数据处理 API,支持多种编程语言和运行时环境。Flink 的核心优点包括: 低延迟:Flink 可以在毫秒级的时间内处理数据,提供了低延迟的数据…

架构(十五)Java字节码增强

一、引言 一般如果需要做增强类的架构工具会使用SpringBoot提供的切面,但是这逃不开两个问题:1、使用方需要加注解代码;2、版本更新导致的发布。 所以java还提供了字节码层面的增强方案,对使用的系统是无感的。 二、字节码增强选…

数独游戏(dfs)

代码注释如下 #include <iostream> using namespace std; const int N 10; bool col[N][N], rol[N][N], cell[3][3][N]; char g[N][N]; bool dfs(int x, int y) { //用bool这样在找到一个方案就可以迅速退出if(y 9) x, y 0; //若y超出边界&#xff0c;则第二…

李沐动手学习深度学习——3.6练习

本节直接实现了基于数学定义softmax运算的softmax函数。这可能会导致什么问题&#xff1f;提示&#xff1a;尝试计算exp(50)的大小。 可能存在超过计算机最大64位的存储&#xff0c;导致精度溢出&#xff0c;影响最终计算结果。 本节中的函数cross_entropy是根据交叉熵损失函数…

人工智能指数报告2023

人工智能指数报告2023 主要要点第 1 章 研究与开发第 2 章 技术性能第 3 章 人工智能技术伦理第 4 章 经济第 5 章 教育第 6 章 政策与治理第 7 章 多样性第 8 章 舆论 人工智能指数是斯坦福大学以人为本的人工智能研究所&#xff08;HAI&#xff09;的一项独立倡议&#xff0c…

基于 LLaMA 和 LangChain 实践本地 AI 知识库

有时候,我难免不由地感慨,真实的人类世界,本就是一个巨大的娱乐圈,即使是在英雄辈出的 IT 行业。数日前,Google 正式对外发布了 Gemini 1.5 Pro,一个建立在 Transformer 和 MoE 架构上的多模态模型。可惜,这个被 Google 寄予厚望的产品并未激起多少水花,因为就在同一天…

STM32 中断流程介绍

STM32可以产生中断的事件多种多样&#xff0c;比如&#xff1a;定时器时间结束、串口接收到数据、某个GPIO检测到电平变化等等等等。 1、STM32 gpio 中断处理流程介绍 1、从引脚进入的高低电平首先由输入驱动器处理&#xff0c;如下图 2、经过输入驱动器处理后的信号会进…

BUUCTF---[极客大挑战 2019]LoveSQL1

1.题目描述 2.一般遇到登录&#xff0c;用户名会尝试admin&#xff0c;密码会尝试万能密码" or 11#或者 or 11#。这里尝试了第一种&#xff0c;但是不对。 3.接着尝试第二种 or 11#。提示登录成功了说明这里是单引号注入&#xff0c;并给了一串字符 4.sql注入题一般会设计…

获取linuxIP、内存、cpu、磁盘IO等信息的Shell脚本及其讲解

shell基础知识 1.grep grep是一个在Unix和Unix-like系统上使用的命令行工具&#xff0c;用于在文本文件中搜索匹配指定模式的行。它的名字来自于"global regular expression print"&#xff08;全局正则表达式打印&#xff09;的缩写。grep的基本用法是通过指定一个…

神经网络之万能定理python-pytorch实现,可以拟合任意曲线

神经网络之万能定理python-pytorch实现&#xff0c;可以拟合任意曲线 博主&#xff0c;这几天一直在做这个曲线拟合的实验&#xff0c;讲道理&#xff0c;网上可能也有很多这方面的资料&#xff0c;但是博主其实试了很多&#xff0c;效果只能对一般的曲线还行&#xff0c;稍微…

设计模式——中介者模式(mediator pattern)

概述 如果在一个系统中对象之间的联系呈现为网状结构&#xff0c;如下图所示。对象之间存在大量的多对多联系&#xff0c;将导致系统非常复杂&#xff0c;这些对象既会影响别的对象&#xff0c;也会被别的对象所影响&#xff0c;这些对象称为同事对象&#xff0c;它们之间通过彼…

智慧市容环境卫生管理信息系统建设项目初步设计参考指南

第四章项目建设方案 梳理和编制数据标准规范&#xff0c;为数据体系建设提供建设指导。数据标准规范体系是根据统一市容环卫基础数据资源建立的&#xff0c;从要素分类、编码、符号、制图、更新机制等层 面解决各类规划标准不衔接、各自为政问题。标准规范体系包括&#xff1…

数据挖掘入门项目二手交易车价格预测之数据分析

文章目录 1. 相关库的引入2. 数据的加载3. 数据概况3.1 统计值查看3.2 查看数据类型 4. 判断缺失值4.1 统计每一列空值的数量4.2 可视化缺失值数量 5. 判断异常值5.1 异常值检测 6. 了解预测值的分布6.1 统计各预测值的分布6.2 总体分布概况6.2 查看预测值的具体频数6.3 查看sk…

HTTPS的实现原理

图片来源&#xff1a;HTTPS 详解一&#xff1a;附带最精美详尽的 HTTPS 原理图 - 个人文章 - SegmentFault 思否 加密流程按图中的序号分为&#xff1a; 客户端请求 HTTPS 网址&#xff0c;然后连接到 server 的 443 端口 (HTTPS 默认端口&#xff0c;类似于 HTTP 的80端口)。…

双周回顾#006 - 这三个月

断更啦~~ 上次更新时间 2023/11/23, 断更近三个月的时间。 先狡辩下&#xff0c;因为忙、着实忙。因为忙&#xff0c;心安理得给断更找了个借口&#xff0c;批评下自己~~ 这三个月在做啥&#xff1f;跨部门援助&#xff0c;支援公司互联网的 ToC 项目&#xff0c;一言难尽。 …

【随记】分享第1期(2024.03.02)

记录这段时间&#xff0c;看到的有趣/有用/值得分享的东西 灵感来源&#xff1a;分类&#xff1a;周刊 - 阮一峰的网络日志 (ruanyifeng.com) 文章目录 大佬博客实用工具文章文摘 大佬博客 云风的 BLOG (codingnow.com) 美团技术团队 (meituan.com) 计算机科学 – 刘未鹏 | Mi…

可以用来测试的接口

实际开发过程中&#xff0c;我们可以通过postman工具来测试接口 get请求 https://api.github.com/events?id1&nameuser post请求 http://httpbin.org/post 参数1&#xff1a;key1value1 参数2&#xff1a;key2value2

springboot238光影视频

光影视频平台 摘 要 使用旧方法对光影视频平台的信息进行系统化管理已经不再让人们信赖了&#xff0c;把现在的网络信息技术运用在光影视频平台的管理上面可以解决许多信息管理上面的难题&#xff0c;比如处理数据时间很长&#xff0c;数据存在错误不能及时纠正等问题。这次开…

第二讲:用geth和以太坊交互

一&#xff1a;安装geth brew install ethereum geth github网址&#xff1a; https://github.com/ethereum/go-ethereum 二&#xff1a; 用geth连接以太坊 以太坊有主网络&#xff08;Ethereum Mainnet&#xff09;&#xff0c;有测试网络&#xff08;Sepolia、Goerli 等等…