【MySQL】数据库知识突破:数据类型全解析与详解

        前言:本节内容讲述MySQL的数据类型,  我们在学习之前的建表的时候已经用过各种各样的数据类型。 比如int、varchar、char类型等等。其中它们是对表的结构的操作, 并没有对数据的内容进行操作,所以它叫做DDL。另外,还有许多其他的数据类型以及其中的细节我们并不清楚。 本节就是具体的对于MySQL中的数据类型进行一些列讲解。

        ps:本节内容建议学习了建库和建表的友友们进行观看。 

目录

数值类型 

tinyint

bit类型

浮点类型

float

decimal

字符串类型

char

varchar

日期和事件类型

enum和set 

enum

set

 如何查找


数值类型 

        数值类型主要有tinyint(1字节)smallint(2字节)mediumint(3字节)int(4字节)bigint(8字节)等,这么多类型都叫做整数类型。其中如果不加unsigned默认为带符号的整形,, 带上unsigned叫做不带符号的整形类型。         

tinyint

        我们先在创建一个表, 这个表里面只有一个tinyint类型:

        然后我们对立面进行插入:

        我们插入之后就会发现,当我们插入-128可以, 插入-127也可以, 插入127也可以。 但是插入128就不行了, 插入-129就不行了。 并且报错说了超出范围。

        然后创建一个无符号的tinyint类型, 然后我们再插入负数就不行了。 并且整数我们可以插入到了255。 负数和256以上都差入不了。

         也就是说, 这个和我们的语言是不一样的。语言如果插入的太大, 语言就会帮助我们进行截断。但是mysql不能截断,该插入多少就是多少, 超过了这个范围就插入失败!!反过来, 如果我们已经有数据插入到了mysql中, 那么这个数据就一定是合法的。 所以,mysql中, 一般而言, 数据类型本身也是一种约束!!!就能保证数据库中的数据是可预期、合法的。

        ps:smallint 、midumint、int类型和tinyint类似, 这里不做演示。

bit类型

        bit类型,为类型。 使用的时候就是bit(M)。M指定位数, 默认为1, 范围是1 ~ 6。

        

我们创建一个bit类型, 大小为1,那么我们插入的时候, 特定字段就不能插入超过2。 

浮点类型

float

        float类型如何使用呢? 

        float[(m, d)]:这里面的m指定的是显示的长度, d指定的是小数的位数。整个float占用4个字节。

        下面我们创建一个float类型的表, 来进行插入示范一下:

        上面我们是创建一个4个位数, 然后小数点后面指定必须是2位。 然后也就是说整数部分一定只能是2位。

        然后, 我们一开始就是正常插入99.99, 显然可以插入; float是有符号的,所以我们插入-99.99的时候也可以插入;如果我们的整数部分插入的时候不是两位而是大于两位, 999.99, 那么就不能插入, 因为规定了整数部分必须是两位。 即便是999.9也不可以, 因为整数部分必须是两位; 当小数部分插入的时候不是两位, 如果是小于两位就补零。 相当于插入99.9其实插入的是99.90;如果小数部分插入的时候大于两位, 那么就进行四舍五入, 比如99.994234324324, 那么对第二位的后一位进行四舍五入为99.99。 但是如果是99.995, 四舍五入为100.00所以就不行了。 

        ps: 那么对于有符号的float(4, 2)类型, 范围是(-99.99 ~ 99.99) 。 无符号是(0 ~ 99.99) ,这里不做讲解,自行验证。

 现在我们使用一下float的默认的存储范围:

        我们会发现,我们插入了一个很大的数字, 但是他只给我们存储了整数的部分, 并且整数的部分也不准, 也有精度损失。 所以我们就能观察到, 其实float是有精度损失的。 

decimal

        decimal也是浮点类型。 float如果存储的数字很大就不准了, 但是decimal不会。 decimal的用法和float类似, 也是decimal[m, d]:m指定长度, d指定小数部分的位数。

        我们下面进行两者的对比:

 

        我们的float和decimal都是用了(10, 8), 也就是两个整数位, 8个小数位。 然后插入相同的数据我们会发现两者的插入结果不一样。 其中float的类型插入的数据精度丢失, 而decimal的精度没有丢失。 

字符串类型

char

        char是固定长度字符串, L是可以存储的长度,单位为字符, 最大的长度可以为255。

        我们创建的char(2), 意思就是创建的两个字符的类型。 然后我们插入一个'a', 可以插入; 插入'ab'可以插入; 插入'abc', 不可以插入了。 说明一个字符就是占用一个位。 char(2)就可以插入两个字符。 但是我们如果插入一个汉字”中', 可以插入, 为什么插入'中国'也可以插入呢?我们知道, 一个汉字在utf8中是3个字节。 所以,我们就可以推断, 在mysql中的一个字符, 不同于语言一个字符就是一个字节。 mysql的一个字符就是一个字符, 一个汉字也是一个字符!!

varchar

        varchar是边长字符串。 他的最大长度是65535, 比char要大。

        由上面的例子我们就可以看到, varchar类似于char, 也是一个汉字就是一个字符。 括号里是多少, 就是创建多少字符的类型。 

        现在,我们看一下下面这个:

        我们创建一个65535大小的varchar类型,就会报错说类型太大了。 但是我们上面不是说varchar的类型最大时65535吗? 这里的65535是说的字节, 而不是字符个数。而字符数就是他说的这个16383。 

        另外 , 关于varchar(len), 这个len到底是多大, 和表的编码是相关的。 根据一个字符占多少来进行计算出来的。 比如utf8就是65535 / 3 = 21845, gb就是65535 / 2 = 32767. 在mysql8.0里面是utf8mb4, 和上面有不一样。 并且, 如果是char, 我们要len个字符, 就是给我们6个字符的空间。 但是对于varchar, 我们虽然要了len个字符, 但是如果实际中我们只是用了1个字符, 那么varchar就只会给我们1个字符的空间, 这个len对于varchar只是一个上限。

        还有, varchar中其实有1 ~ 3个字节用于记录数据大小, 所以我们实际上varchar最大的字节数是65535 - 3。

然后char和varchar的优缺点就很容易看出来:

  •         varchar变长:效率低, 节省空间。
  •         char定长:效率高, 浪费空间。

日期和事件类型

        date:日期,'yyyy-mm-dd'占3个字节。

        datetime:日期和时间,'yyyy-mm-dd HH:ii:ss' 占8个字节。

        timestamp:时间戳, 从1970年开始进行计算, 占用4个字节。

enum和set 

enum

        enum是枚举类型, 枚举类型是我们只能在枚举出来的选项中选择一个。 是多选一:

        我们如果创建一个gender枚举男和女。 我们插入的时候如果插入男, 可以插入; 如果插入女, 也可以。 但是如果插入别的, 就不行了。 

        但是, 我们可以插入1和2:

        这是因为在枚举中, 枚举变量的下标是从1开始的, 然后以此类推。 我们进行插入时, 也可以利用下标来代指枚举变量。

set

还是我们上面的t12这个表:

        在插入的过程中, 我们有可能遇到这种情况, 就是我们一个人, 比如说赵六, 他既喜欢游泳, 又喜欢写代码。 那么怎么办呢? 这个就要用到集合:

        所以, 我们插入集合的方法就是一个' ', 中间可以写集合里面的元素,中间用逗号分割。

        另外, 我们如果想要让数字表示集合的元素。 规则和枚举不一样。 这里使用的是二进制来表示对应位置的元素有没有进行插入。 就比如我们上面创建的表, 我们的表的集合里面一共有四个元素。 如果全部插入就是1111(二进制); 如果是不插入游泳就是111; 如果插入不插入乒乓球, 就是1101; 如果不插入代码, 不插入羽毛球, 插入乒乓球和游泳就是1100。现在来测试:

 如何查找

        查找enum比较简单, 执行select where语句即可:

        查找set, 假如我们想要查找只喜欢羽毛球的人容易查找, 直接select where:

        但是如果我们想要的是喜欢羽毛球的人, 这些人也肯能喜欢乒乓球, 可能喜欢游泳啥的。 这个时候它们就不能被选到。所以这里就要用到一个函数find_in_set。 select 是可以执行函数的。 这个find_in_set的作用就是查找集合里面的某一个元素, 并且返回这个元素的下标。 如果返回0, 那么没有查找到: 

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

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

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

相关文章

windows 11编译安装ffmpeg(包含ffplay)

一、源码及安装包下载 1.1,ffmpeg源码包下载 下载地址:Download FFmpeg 1.2,mysys下载 下载地址:MSYS2 1.3,libx264源码包下载 下载地址:x264, the best H.264/AVC encoder - VideoLAN 二、软件安装 2.1&…

从0开始深度学习(28)——序列模型

序列模型是指一类特别设计来处理序列数据的神经网络模型。序列数据指的是数据中的每个元素都有先后顺序,比如时间序列数据(股票价格、天气变化等)、自然语言文本(句子中的单词顺序)、语音信号等。 1 统计工具 前面介绍…

【考研数学:高数2】数列极限

目录 前言 一、数列极限的概念 1.常见前n项和 2.等差、等比数列 3.数列的性质 (1)单调性 (2)有界性 二、数列极限的定义 三、收敛数列的性质 1.概念 2.例题 四、极限的四则运算 五、海涅定理(归结原则&…

计算机网络分析题

网络的布置 根据具体需求布置网络 第二小题、网络的划分 根据路由表作出路由器拓扑图 ARP跨网络寻址 TCP报文段格式概念 网桥的转发表与动作 网络嗅探报文 十六进制化作十进制 嗅探以太网帧首部 除MAC帧以外,其他各层协议数据单元都是源地址在前,目…

PHP爬虫快速获取京东商品详情(代码示例)

在当今互联网时代,数据的重要性不言而喻。对于电商领域来说,获取商品信息是数据分析、市场研究和价格监控的基础。本文将介绍如何使用PHP编写一个简单的爬虫,以快速获取京东商品的详情信息。 1. 概述 京东是中国领先的电商平台之一&#xff…

快速学习Serde包实现rust对象序列化

在处理HTTP请求时,我们总是需要在数据结构对象(可以是enum、struct等)和序列化数据格式(例如JSON,用与存储或传输,并可以反序列化的格式)之间来回转换。 Serde是一个库(crate&#x…

OLED 显示画面的变换操作——上下、左右翻转

OLED 画面旋转 OLED 写入函数定义 OLED_WR_Byte(0xA1,OLED_CMD);//--Set SEG/Column Mapping 0xa0左右反置 0xa1正常 OLED_WR_Byte(0xC8,OLED_CMD);//Set COM/Row Scan Direction 0xc0上下反置 0xc8正常OLED 显示界面转换函数如下 void OLED_DisplayTurn(u8 i) {if(i0…

由播客转向个人定制的音频频道(1)平台搭建

项目的背景 最近开始听喜马拉雅播客的内容,但是发现许多不方便的地方。 休息的时候收听喜马拉雅,但是还需要不断地选择喜马拉雅的内容,比较麻烦,而且黑灯操作反而伤眼睛。 喜马拉雅为代表的播客平台都是VOD 形式的&#xff0…

luckfox-pico-max学习记录

0.文件编译及烧录 SDK包在文件夹/home/tao/linux/luckfox/luckfox-pico-spi应用程序样例在文件夹/home/tao/linux/luckfox-pico-spi/demo编译:sudo ./build.sh生成的镜像文件在./luckfox-pico-spi/output/image中,将所有文件复制到windows电脑文件夹I:\…

一文了解珈和科技在农业遥感领域的服务内容和能力

2020年,农业农村部、中央网信办联合印发了《数字农业农村发展规划(2019-2025年)》,对数字农业农村建设作出了具体部署。其中,农业遥感作为推进数字农业农村的重要力量贯穿《规划》始终。 今年10月,农业农村…

羊城杯2020Easyphp

审题 看到url,可以想到伪协议读取 尝试过后可以发现,题目绕过了read后面的编码 我们可以尝试双重urlencode进行绕过 ?filephp://filter/read%25%36%33%25%36%66%25%36%65%25%37%36%25%36%35%25%37%32%25%37%34%25%32%65%25%36%32%25%36%31%25%37%33%…

【时间之外】IT人求职和创业应知【34】-人和机器人,机器人更可靠

目录 新闻一:人形机器人产业持续高速增长,2026年中国市场规模将突破200亿元 新闻二:AI技术驱动设备厂商格局变化,部分厂商市占率快速提升 新闻三:华为与江淮汽车携手打造超高端品牌“尊界”,计划于明年春…

Linux——基础指令2 + 权限

目录 1.zip/unzip 2.tar 3.bc 4.uname –r 5.重要的几个热键 6.扩展命令 7.shell命令以及运行原理 8.Linux权限的理解 关于权限的三个问题: 1.目录权限 2.缺省权限 3.粘滞位 1.zip/unzip 打包、压缩:使用特定的算法,文件进行合…

pgsql和mysql的自增主键差异

1. 当有历史数据存在时, mysql的自增主键是默认从最大值自增。 pgsql的自增主键取初始值开始逐个尝试,所以存在可能与历史数据的主键重复的情况。 pgsql解决上述问题的方式:重设自增值。 SELECT SETVAL(t_db_filed_id_seq, (SELECT MAX(&q…

【Linux】基础IO及文件描述符相关内容详细梳理

0. C语言文件I/O 在C语言中,我们学习了相关函数来读写文件,例如:fopen,fwrite,fread,fprintf等, 在C语言中文件的打开方式: r Open text file for reading. …

大语言模型在序列推荐中的应用

一、简介 序列推荐技术通过分析用户的过往交互历史,能够有效挖掘出用户可能感兴趣的项目,对于提升各类应用的服务质量具有重要作用。近期,大语言模型(LLMs)的发展在应对复杂的推荐问题上展现出了显著的优势。不过&…

JavaScript——函数、事件与BOM对象

一、系统函数(JS中预置的函数) JS的预置函数在遇到非数字字符时会停止解析 parseInt 转整型 parseFloat 转浮点型 isNaN !isNaN("10") 检测是否纯数字 eval 把字符串转成算式并计算 1.parseInt(string, radix); 语法: string&#x…

Python酷库之旅-第三方库Pandas(208)

目录 一、用法精讲 971、pandas.MultiIndex.set_levels方法 971-1、语法 971-2、参数 971-3、功能 971-4、返回值 971-5、说明 971-6、用法 971-6-1、数据准备 971-6-2、代码示例 971-6-3、结果输出 972、pandas.MultiIndex.from_arrays类方法 972-1、语法 972-2…

相亲小程序(源码+文档+部署+讲解)

最近我在挖掘一些优秀的开源项目时,无意间发现了一个相当给力的系统——相亲小程序管理系统。这个系统不仅功能实用,而且代码结构清晰,易于二次开发。作为一名技术爱好者,我觉得有必要把这个好东西推荐给我的读者们。接下来&#…

spring cloud 入门笔记1(RestTemplate,Consul)

最大感受: spring cloud无非是将spring boot中的各个工作模块拆分成独立的小spring boot,各个模块之间,不再是通过导包什么的,调用而是通过网路进行各个模块之间的调用 工具一:RestTemplate 在Java代码中发送HTTP请…