【MySQL】数据库必备知识:全面整合表的约束与深度解析

news2024/12/24 9:27:15

        前言:本节内容讲述表的约束的相关内容。 表的约束博主将会通过两篇文章进行讲解, 这是第一篇上半部分。 讲到了约束概念。 以及几种常见约束。下面友友们开始学习吧!

        ps:友友们使用了mysql就可以放心观看喽!

目录

表的约束概念

非空约束

 default默认值

default

非空和默认的区别   

列描述

zerofill

主键

去掉主键       

建表后添加主键

多列主键


表的约束概念

        表的约束要让用户在数据库当中安全的插入数据, 就必须要有表的约束。 否则就比如我们的这个表的这一行信息应该插入性别, 但是有没有用户在上层插入了一个人名呢? ——所以, 为了避免这些问题。表中就要有各种约束, 通过约束, 让我们未来插入数据库表中的数据是符合预期的。 

        约束本质是通过技术手段倒逼程序员插入正确的数据。反过来站在mysql的角度, 凡是插入进来的数据都是符合数据约束的。

        约束的最终目标就是保证数据的完整性和可预期性。 

        综上, 所以为了能够更好的使用数据库, 我们就需要更多的约束条件

非空约束

        NULL VS '  '这两个有什么区别呢? 其中'   '并不是什么都没有, 而是表示插入的是一个空串, 是一个字符串, 只不过这个字符串是空的。 而NULL是什么都没有。 (NULL是不参与运算的。)

        非空约束有两个:一个是null(默认的为空) 和 not null(不为空)。什么意思, 就是说我们建表的时候,如果不带null和not null。 那么默认的就是null, 也就是该列属性可以为空。 而如果我们想要让该列属性不能为空, 就必须添加一个not null。 

        下面为例子:

create table if not exists class(
 class_name varchar(20) not null,
class_room varchar(20) not null,
other varchar(20) 
);

        desc后的显示结果中有一列: Null,下面有的是NO, 有的是YES。  这里的NO就是不允许为空。 如果插入空, 那么就报错:

insert into class values(null, 103, 104);
insert into class values(103, null, 104);
insert into class values(103, 103, 104);

 default默认值

default

        default是默认值, 就比如说我们在插入数据的时候, 有可能某一列没有插入数据, 那么这个时候如果有默认值, 这个列就能自动的插入一个默认值。

        下面为示例:

mysql> create table if not exists t13(
    -> name varchar(20) not null,
    -> age tinyint unsigned default 18,
    -> gender char(1) default '男'
    -> );

        然后我们就能看到上面的我们没有设置not null的就是默认可以为空。 然后后面有一个Default, 这个Default默认是NULL, 空没有默认值。 然后我们设置后, 就出现了默认值18或者男。

       只插入name, 然后age和gender都被插入了默认值。  

非空和默认的区别   

    接下来测试非空和默认的区别:

mysql> create table if not exists t14(
    -> name varchar(20) not null,
    -> age tinyint default 18,
    -> gender char(1) not null default '男'
    -> );

我们先测试name:

        这里我们首先插入了一个NULL,给我们报错是不能为空。 这符合我们的语气,因为NULL就是代表空。 而name不能为空, 所以会报错。

        问题是第二个报错。 我们对name列没有进行插入, 但是他报错了没有默认值。 ——所以, 这里就有一个结论: 如果我们某一列设置了not null, 那么我们没有明确指定一列要插入, 用的就是default,如果建表中对应列默认没有设置default, 无法直接插入。

        gender既有not null, 又有default, 所以按照刚刚的结论就应该可以插入:

        可以观察到插入成功。

        所以default 和 NOT NULL不冲突, 而是互相补充的。当用户想插入的时候, 就是NULL和NOT NULL来约束(插入NULL 、合法数据、不合法数据) ;当用户忽略这一列的时候, 就是使用default来约束:如果设置了就是使用默认值。 如果没有设置, 那么就会报错!!!。

        但是, 我们之前插入的时候, 明明是可以忽略某一列的啊, 就比如下面这样:

        我们创建一个表, 这个表当中三列, 都没有设置默认值。 但是我们也可以忽略gender这一列啊。 这是为什么呢? 是不是上面我们的结论出错了呢? ——答案是不是的。 这是因为mysql在我们创建表的时候做了优化, 如果我们不带默认值, 他就会默认给我们添加默认值NULL:

列描述

        列描述就相当于对表当中的字段进行说明。就是一种描述字段。并没有说如果不符合规则就不让插入。 

mysql> create table if not exists t16(
    -> name varchar(20) not null comment'这个是用户的用户名',
    -> age tinyint unsigned default 18 comment '这个是用户的年龄',
    -> gender char(1) not null default '男' comment '这个是用户的性别'
    -> );

zerofill

        zerofill其实就是将数据的所有位全部用0填充,格式化显示。就是如果插入的数据的宽度小于限定的宽度, 那么就补零。如果超出了宽度, 那么就要原本的数据位数。 

        下面为示例:

create table t18( a int unsigned zerofill, b int unsigned );

        上面可以看到我们使用zerofile创建的a变量, int类型是申请了10个空间。 然后我们插入一些数据:

然后我们就能看到, a这里除了一个1, 前面的位都被0填满了。 

主键

        主键约束就是我们在建表的时候, 有一列信息标定该一条信息的唯一性,并且这一列信息不能为空。也就是主键列不能重复, 不能为空。 一张表中最多只能有一个主键。主键所在的列通常是整型类型。

         下面为示例:

mysql> create table if not exists test_key(
    -> id int unsigned primary key comment '这个是学生的学号',
    -> name varchar(20) not null,
    -> gender char(1) 
    -> );


        通过上面的例子我们观察, 其中我们的id是一个主键列, 这个id的Key的位置被设置成为了PRI,意思就是主键列。 然后Null变成了不能为空。 这个是主键列的性质。

        插入的时候我们的id重复, 就会报错!!

去掉主键       

alter table 表名 drop primary key;

然后就能重复插入了:

建表后添加主键

alter table 表名称 add primary key(id);

 我们上面添加失败是因为id列有许多重复的元素。 所以我们想要添加主键就要将去重:

我们去重之后就能插入了。

多列主键

        一个主键可以被添加到一列或者多列, 这类多列主键叫做符合主键。

        下面为示例:

mysql> create table t19(
    -> id int unsigned,
    -> course_id int unsigned comment'课程编号',
    -> score tinyint unsigned comment'这个学生这门课程的分数',
    -> primary key (id, course_id)
    -> );


        我们创建好了之后, id和course_id合起来才称为一个主键。 下面我们测试插入数据:

insert into t19 values(1234, 40, 90);
insert into t19 values(1235, 40, 90);
insert into t19 values(1235, 41, 90);
insert into t19 values(1235, 40, 90);

        然后我们就能发现我们重复可以让1234选择40这门课, 1235也可以选择40这门课。 1235也可以选择41这门课。 但是1235再次选择40这门课的时候就出错了!

        所以, 多列主键就是, 列之中只要有一个数据不一样, 就可以进行插入。只有当所有数据都一样的时候才不可以插入。

  ——————以上就是本节全部内容哦, 如果对友友们有帮助的话可以关注博主, 方便学习更多知识哦!!!    

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

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

相关文章

堆排序,学习笔记

目录 一、概念 二、堆排序的基本思路 三、堆排序的基本步骤 1. 构建初始堆: 2. 排序过程 四、示例 五、应用场景 1. 优先级队列相关场景 2. TopK 值问题 一、概念 堆排序是一种基于二叉堆数据结构的排序算法。二叉堆是一种完全二叉树,它分为两种…

分享 pdf 转 word 的免费平台

背景 找了很多 pdf 转 word 的平台都骗进去要会员,终于找到一个真正免费的,遂分享。 网址 PDF转Word转换器 - 100%免费市面上最优质的PDF转Word转换器 - 免费且易于使用。无附加水印 - 快速将PDF转成Word。https://smallpdf.com/cn/pdf-to-word

llama-cpp模型轻量化部署与量化

一、定义 定义配置环境遇到的问题,交互模式下模型一直输出,不会停止模型量化Qwen1.5-7B 案例demo 二、实现 定义 主要应用与cpu 上的部署框架。由c完成。配置环境 https://github.com/ggerganov/llama.cpp https://github.com/echonoshy/cgft-llm/blo…

2024最新版JavaScript逆向爬虫教程-------基础篇之Proxy与Reflect详解

目录 一、监听对象的操作二、Proxy基本使用2.1 创建空代理2.2 定义捕获器2.2.1 Proxy的set和get捕获器2.2.2 Proxy(handler)的13个捕获器 三、Reflect的作用3.1 Reflect的使用3.2 Reflect其余方法(9个)3.3 Proxy与Reflect中的receiver参数3.4 Reflect中的construct方法 ECMAScr…

Ceph层次架构分析

Ceph的层次结构可以从逻辑上自下向上分为以下几个层次: 一、基础存储系统RADOS层 功能:RADOS(Reliable Autonomic Distributed Object Store)是Ceph的底层存储系统,提供了分布式存储的核心功能。它是一个完整的对象存…

webpack指南

​🌈个人主页:前端青山 🔥系列专栏:webpack篇 🔖人终将被年少不可得之物困其一生 依旧青山,本期给大家带来webpack篇专栏内容:webpack-指南 概念 中文: webpack | webpack中文文档 | webpack中文网 英文&…

网站架构知识之nginx第三天(day026 )

1.状态模块 使用方法:location /status/{ stub_$status; } 任意一个虚拟主机添加这个,就可以查看nginx状态。 对应指标及其说明

新的恶意软件活动通过游戏应用程序瞄准 Windows 用户

一种新的恶意软件 Winos4.0 被积极用于网络攻击活动。FortiGuard实验室发现,这种先进的恶意框架是从臭名昭著的 Gh0strat 演变而来的,配备了模块化组件,可在受感染的设备上进行一系列恶意活动。 这些攻击已在游戏相关应用程序中发现&#xf…

Redis - 集群(Cluster)

一、基本概念 上述的哨兵模式,提⾼了系统的可⽤性.但是真正⽤来存储数据的还是master和slave节点.所有的数 据都需要存储在单个master和slave节点中. 如果数据量很⼤,接近超出了master/slave所在机器的物理内存,就可能出现严重问题了. 如何获取更⼤的空间?加机器即可!所谓&q…

WebRTC项目一对一视频

开发步骤 1.客户端显示界面 2.打开摄像头并显示到页面 3.websocket连接 4.join、new-peer、resp-join信令实现 5.leave、peer-leave信令实现 6.offer、answer、candidate信令实现 7.综合调试和完善 1.客户端显示界面 步骤:创建html页面 主要是input、button、vide…

启动本地开发环境(自带热启动)yarn serve

文章目录 1. 安装 Yarn使用 npm 安装 Yarn使用 Chocolatey 安装 Yarn(Windows 用户)使用 Homebrew 安装 Yarn(macOS 用户) 2. 安装项目依赖3. 启动项目开发模式启动生产模式启动 4. 构建项目开发模式构建生产模式构建 5. 其他常用…

SpringCloud框架学习(第二部分:Consul、LoadBalancer和openFeign)

目录 六、Consul服务注册和发现 1.基本介绍 2.下载运行 3.服务注册与发现 (1)支付服务provider8001注册进consul (2)修改订单服务cloud-consumer-order80 4.CAP (1)CAP理论 (2&#x…

SAP ABAP开发学习记录——报表选择界面初始值

程序中定义选择界面的部分只是创建输入框,在后续使用中需要自行添加搜索条件,而有关时间或者日期这种,希望自动创建一个默认值,有两种方法,一种是在选择界面初始化时增加语句另外一种是通过在选择界面创建变式实现。 …

16.UE5拉怪机制,怪物攻击玩家,伤害源,修复原视频中的BUG

2-18 拉怪机制,怪物攻击玩家、伤害源、黑板_哔哩哔哩_bilibili 目录 1.实行行为树实现拉怪机制 1.1行为树黑板 1.2获取施加伤害对象(伤害源) 2.修复原视频中,第二次攻击怪物后,怪物卡在原地不动的BUG 3.怪物攻击玩…

大数据新视界 -- 大数据大厂之 Impala 性能飞跃:动态分区调整的策略与方法(上)(21 / 30)

💖💖💖亲爱的朋友们,热烈欢迎你们来到 青云交的博客!能与你们在此邂逅,我满心欢喜,深感无比荣幸。在这个瞬息万变的时代,我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

Vue3 笔记 (万字速通)

此笔记来至于尚硅谷,仅供笔者复习使用 1. Vue3 简介 2020年9月18日,Vue.js发布版3.0版本,代号:One Piece(n) 经历了:4800次提交、40个RFC、600次PR、300贡献者 官方发版地址:Rele…

Linux基础1

Linux基础1 Linux基础1学习笔记 ‍ 声明! ​​​学习视频来自B站up主 泷羽sec 有兴趣的师傅可以关注一下,如涉及侵权马上删除文章 笔记只是方便各位师傅的学习和探讨,文章所提到的网站以及内容,只做学习交流,其他…

Linux中.NET读取excel组件,不会出现The type initializer for ‘Gdip‘ threw an exception异常

组件,可通过nuget安装,直接搜名字: ExcelDataReader using ConsoleAppReadFileData.Model; using ExcelDataReader; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Task…

320页PDF | 集团IT蓝图总体规划报告-德勤(限免下载)

一、前言 这份报告是集团IT蓝图总体规划报告-德勤。在报告中详细阐述了德勤为某集团制定的全面IT蓝图总体规划,包括了集团信息化目标蓝图、IT应用规划、数据规划、IT集成架构、IT基础设施规划以及IT治理体系规划等关键领域,旨在为集团未来的信息化发展提…

乐维网管平台(六):如何正确管理设备端口

一、什么是端口下联 在网络环境中,端口下联是指网络设备(通常是交换机)的端口与其他设备相连接的一种网络架构关系。交换机作为网络中的核心连接设备,其端口下联可以连接多种类型的终端设备,如计算机、服务器、IP 电话…