MySQL(三)-数据类型

news2025/1/19 2:18:44

MYSQL数据类型

  • 1 整数类型
  • 2 浮点数类型和定点数类型
  • 3 日期与时间类型
  • 4 文本字符串类型
  • 5 二进制字符串类型
  • 6 数据类型的选择

表是由多列字段组成,每一个字段会有不同的数据类型,不同的数据类型决定了字段包含的数据内容。不同的数据类型也决定了mysql在使用他们的时候的方式。

1 整数类型

数据型数据类型主要用来存储数字,不同的数据类型提供不同的取值范围,可以存储的值的范围越大,所需要的存储空间也会越大。
在这里插入图片描述
1. TINYINT:

用于存储范围在 -128 到 127 之间的整数。如果使用 UNSIGNED 关键字,则范围变为 0 到 255,存储需求为1字节。

2. SMALLINT:

用于存储范围在 -32,768 到 32,767 之间的整数。如果使用 UNSIGNED 关键字,则范围变为 0 到 65,535,存储需求为2字节。

3. MEDIUMINT:

用于存储范围在 -8,388,608 到 8,388,607 之间的整数。如果使用 UNSIGNED 关键字,则范围变为 0 到 16,777,215,存储需求为3字节。

4. INT 或 INTEGER:

用于存储范围在 -2,147,483,648 到 2,147,483,647 之间的整数。如果使用 UNSIGNED 关键字,则范围变为 0 到 4,294,967,295,存储需求为4字节。

5. BIGINT:

用于存储范围在 -9,223,372,036,854,775,808 到 9,223,372,036,854,775,807 之间的整数。如果使用 UNSIGNED 关键字,则范围变为 0 到 18,446,744,073,709,551,615,存储需求为8字节。

2 浮点数类型和定点数类型

MySQL支持两种用于存储小数的数据类型,即浮点数类型和定点数类型。
在这里插入图片描述

1. 浮点数类型

包括FLOAT和DOUBLE,这两种类型都可以存储较大或较小的值,因为它们使用科学记数法表示数值。

FLOAT和DOUBLE的区别在于精度和存储空间大小。FLOAT类型精度为单精度,即4个字节,而DOUBLE类型精度为双精度,即8个字节。

FLOAT和DOUBLE类型的取值范围如下:

FLOAT类型的取值范围为-3.4028235E+38到3.4028235E+38,精度为单精度(4字节)。
DOUBLE类型的取值范围为-1.7976931348623157E+308到1.7976931348623157E+308,精度为双精度(8字节)。

  1. 定点数类型

定点数只有一种类型 DECIMAL。不同于FLOAT和DOUBLE,DECIMAL 实际上是以串的方式存放的,可能取值的范围和DOUBLE类型一样,但是有效的取值范围由精度和标度来确定。
它的存储空间是由精度值来决定的,占用 精度+2 字节。

例如,DECIMAL(8,2)可以存储-999999.99到999999.99之间的值,因为它使用8个数字位,其中2个数字是小数点后的位数。

FLOAT和DOUBLE在不指定精度的前提下,默认会按照实际的精度,DECIMAL如不指定精度,默认为(10,0)。

3 日期与时间类型

MySQL支持多种日期和时间类型,包括日期类型、时间类型、日期时间类型和时间戳类型。
在这里插入图片描述

  1. 日期类型:YEAR

单字节类型,用于表示年,在存储时只需要1字节,可以使用各种格式指定YEAR值。
1)4位字符或者4位数字格式表示的year,范围在 1901~2155,输入格式为’YYYY’或者 YYYY。
2)2位字符串表示的year,范围在00~99,其中00 ~ 69 和70 ~ 99的范围分别会被转换为2000 ~ 2069 和 1970 ~ 1999 的范围。
0 和 00 的范围相同,插入超过取值范围的值会被转换为 2000.
3)2位数字表示的year,范围在1 ~ 99. 1~ 69 和 70 ~ 99 会被转换为2001 ~ 2069 和 1970 ~ 1999 的范围。
注意,在这里 0 值将会装换为 0000 而不是 2000。

  1. 时间类型:TIME

time类型用在只需要时间信息的值,存储室后需要3字节,格式为’HH:MM:SS’ 从前至后分别表示小时,分钟,秒三个时间单位。取值范围为 -838:59:59 ~ 838:59:59,范围如此大的原因在于,不仅仅可以用于表示一天的时间,和可以用于表示过去的时间或者两个时间的时间间隔(可以为负数)。

1)‘D HH:MM:SS’ 格式的字符串,可以使用如下任何一种非严格的语法,‘HH:MM:SS’ ,‘HH:MM’ ,‘D HH:MM’ ,‘D HH’ ,‘SS’。 D在这里可以表示日,取值为0 ~ 34之间的值,插入数据库时,转换为小时保存,格式为 D*24 + HH。
2)‘HHMMSS’ 格式,没有间隔的字符串或者数值,有意义的数值,如 101012 则变为 10:10:12,不合法数据 959897,任意部分取值范围不合法,存储室变为 00:00:00.

  1. 日期时间类型:DATE

用在仅需日期值时,没有时间部分,存储需要 3 字节。日期格式为 ‘YYYY-MM-DD’。从前至后分别表示年,月,日三个时间单位。可使用字符或者数字类型进行数据插入,只要符合日期格式即可。
1)以’YYYY-MM-DD’ 或者’YYYYMMDD’ 的字符串表示的日期为 1000-01-01 ~ 9999-12-3 。 ‘2012-12-11’ 或者 ‘20121211’ 均为 2012-12-11.
2)以’YY-MM-DD’ 或者’YYMMDD’ 的字符串或者数据值表示的日期,YY表示的范围,参考 YEAR数据类型的范围。
3)使用current_date() 或者 NOW() ,插入当前系统日期。

  1. 日期时间类型:DATETIME

表示同时包含日期和时间信息的值,存储室需要8字节。‘YYYY-MM-DD HH:MM:SS’ 从前至后分别表示年,月,日 小时,分钟,秒。可使用字符或者数字类型进行数据插入,只要符合日期格式即可。
1)‘YYYY-MM-DD HH:MM:SS’ 或者 ‘YYYYMMDDHHMMSS’ 字符串格式表示的值,取值范围为 1000-01-01 00:00:00~ 9999-12-3 23:59:59。
2)‘YY-MM-DD HH:MM:SS’ 或者 ‘YYMMDDHHMMSS’ 字符串格式表示的日期,YY表示的范围,参考 YEAR数据类型的范围。
3) ‘YYYYMMDDHHMMSS’ 或者’YYMMDDHHMMSS’ 表示的日期和时间,在合理取值单位内,进行日期插入,如20230421131512 为 2023-04-21 13:15:12 , 980512234511 为 1998-01-12 23:45:11。

  1. 日期时间类型:TIMESTAMP

该类型显示的格式和DATETIME 相同,显示宽度固定在19个字节,日期格式为’YYYY-MM-DD HH:MM:SS’ ,取值范围小于 datatime,范围为 1970:-01-01 00:00:01 ~ 2038-01-19 03:14:07 UTC,UTC为世界标准时间,因此插入数据要在合法的取值范围内。

4 文本字符串类型

字符串类型用来存储字符串数据,可以存储字符串数之外,还可以存储其他数据,如图片和声音等,mysql中文本字符串指定的是CHAR,VARCHAR,TEXT,ENUM,SET。
在这里插入图片描述

  1. CHAR 和 VARCHAR

CHAR(M) 为固定长度字符串,定义时指定长度,保存是在右侧填充空格,已达到执行的字符长度,M为列长度,范围是0 ~ 255 个字符。
VARCHAR(M) 是长度可变的字符串,M表示最大列长度,范围是0 ~ 65535。VARCHAR的实际长度是由最长的行的大小和使用的字符集来决定的,实际占用的空间为字符串的实际长度+1。

  1. TEXT

TEXT列保存非二进制字符串,保存或者查询TEXT列的值的时候,不删除尾部空格。类型分为4种,
TINYTEXT:最多存储 2^8 - 1(即255)个字符,占用空间为 1 个字节。
TEXT:最多存储 2^16 - 1(即65,535)个字符,占用空间为 2 个字节。
MEDIUMTEXT:最多存储 2^24 - 1(即16,777,215)个字符,占用空间为 3 个字节。
LONGTEXT:最多存储 2^32 - 1(即4,294,967,295)个字符,占用空间为 4 个字节。

  1. ENUM

存储枚举值的数据类型,用于存储固定的、有限的可能值集合。在创建表时指定ENUM类型的列时,需要用到ENUM关键字,并且需要指定该列允许的枚举值。

ENUM类型的语法格式为:

ENUM('value1', 'value2', 'value3', ...)

其中,value1、value2、value3等就是该ENUM类型所能存储的枚举值,每个枚举值用单引号括起来,用逗号隔开。

  1. SET类型
    一种存储多个选项的数据类型,用于存储一组固定的、有限的可能选项集合。在创建表时指定SET类型的列时,需要用到SET关键字,并且需要指定该列允许的选项集合。

SET类型的语法格式为:

SET('option1', 'option2', 'option3', ...)

其中,option1、option2、option3等就是该SET类型所能存储的选项,每个选项用单引号括起来,用逗号隔开。

5 二进制字符串类型

二进制字符串类型是MySQL中一种存储二进制数据的数据类型,用于存储一些可能存在二进制数据的数据,如图片、音频、视频等。
在这里插入图片描述

  1. BIT

BIT类型是MySQL中一种存储位数据(二进制位)的数据类型。BIT类型可以存储零个或多个位,其长度由列声明中指定的位数决定。BIT类型可以存储布尔值或者位数据的组合,如二进制数或者旗帜(flag)等。

在MySQL中,BIT类型的长度可以是1到64位,如果不指定长度,MySQL会默认为1。与其他类型不同的是,在顺序排列中,BIT类型中的位是从右到左被编号的,也就是从低位到高位。在创建表时可以使用BIT类型。

  1. BINARY 和 VARBINARY

BINARY和VARBINARY都是MySQL中用来存储二进制数据的数据类型。

BINARY类型是一种固定长度的数据类型,它指定了一个固定的长度作为该列所能存储的二进制数据长度,如果插入的数据长度超过了指定的长度则会被截断。因为它是固定长度的,所以BINARY类型会占用比VARBINARY更多的存储空间。

VARBINARY类型是一种可变长度的二进制数据类型,它可以存储任意长度的二进制数据。因为它是可变的,所以VARBINARY类型只会占用实际数据长度的存储空间。

需要注意的是,虽然BINARY类型和VARBINARY类型都可以存储二进制数据,但它们的使用场景不太相同。BINARY类型适用于固定长度的二进制数据,例如存储MD5值等固定长度的字符串或哈希值;VARBINARY类型适用于可变长度的二进制数据,例如存储文件、视频、图片等任意长度的二进制数据。

  1. BLOB

BLOB是MySQL中一种二进制大型对象数据类型,用于存储大型二进制数据,例如图像、音频、视频等文件。BLOB类型可以存储零个或多个字节数,而且没有数据类型的最大长度。

在MySQL中,有4种类型的BLOB:

TINYBLOB:最大长度为255字节。
BLOB:最大长度为65,535字节。
MEDIUMBLOB:最大长度为16,777,215字节。
LONGBLOB:最大长度为4,294,967,295字节。

6 数据类型的选择

数据类型的选择要根据实际的需求来确定。以下是一些常见的数据类型和使用场景:

INT: 适用于创建表中的ID列、自然数列和计数器列,可以存储范围从-2147483648到2147483647的整数。

BIGINT: 适用于存储大整数,可以存储范围从-9223372036854775808到9223372036854775807的整数。
FLOAT: 适用于存储较小的浮点数,可以存储6个小数位的浮点数。

DOUBLE: 适用于存储更复杂的浮点数,可以存储15个小数位的浮点数。

DECIMAL: 适用于存储精确的小数,可以存储定点数,支持可变的小数位。

VARCHAR: 适用于存储可变长度的字符,可以存储最大65535个字符。

TEXT: 适用于存储不可预知长度的字符,可以存储最大65535个字符。

ENUM: 适用于存储预定的一组值,可以根据需要创建和使用。

DATE: 适用于存储日期,存储范围从1000-01-01到9999-12-31。

TIME: 适用于存储时间,可以存储小时、分钟、秒和毫秒。

在选择数据类型时,需要考虑存储的数据类型和大小,还要考虑查询的效率和可扩展性。因此,如果数据类型不确定,请在设计表时选择较小的数据类型,并在需要时扩展它们。另外,数据类型的选择也要考虑要支持的字符集和排序规则,以及数据的一致性和完整性,并遵循最佳实践。

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

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

相关文章

SpringBoot项目结构及依赖技术栈

目录 1、pom.xml文件配置说明 2、SpringBoot项目结构说明 3、入门案例关键配置说明 🌈 前面我们学习了SpringBoot快速入门案例,本节我们通过POM文件和项目结构分析两部分内容了解下关于SpringBoot的一些配置说明,以便全面了解SpringBoot项…

Javaweb | 转发、重定向

💗wei_shuo的个人主页 💫wei_shuo的学习社区 🌐Hello World ! 转发 转发与页面跳转 转发 转发的作用在服务器端,将请求发送给服务器上的其他资源,以共同完成一次请求的处理 页面跳转 使用forward跳转时&am…

MySQL(七)-日期和时间函数的使用解析

日期和时间函数的使用解析 1 获取当前日期的函数和获取当前时间的函数2 获取当前日期和时间的函数3 UNIX时间戳函数4 返回UTC日期的函数和返 UTC 时间的函数5 获取月份的函数MONTH(date)和 MONTHNAME(date)6 获取星期的函数DAYNAME(d)DAYOFWEEK(d)和WEEKDAY(d)7 获取星期数的函…

芯片封装基本流程及失效分析处理方法

芯片封装 芯片封装的目的在于对芯片进行保护与支撑作用、形成良好的散热与隔绝层、保证芯片的可靠性,使其在应用过程中高效稳定地发挥功效。 工艺流程 硅片减薄 使用物理手段,如磨削、研磨等;或者化学手段,如电化学腐蚀、湿法腐蚀…

2023-04-24:用go语言重写ffmpeg的muxing.c示例。

2023-04-24:用go语言重写ffmpeg的muxing.c示例。 答案2022-04-24: 本程序的大体过程如下: 打开输出文件并写入头部信息。 添加音频和视频流,并为每个流创建 AVCodecContext 对象,根据输入格式设置编码器参数&#x…

springboot 整合itext 实现pdf下载

一 itext介绍 1.1 核心组件介绍 Text中用文本块(Chunk)、短语(Phrase)和段落(paragraph)处理文本。 1.文本块(Chunk)是处理文本的最小单位,有一串带格式(包括字体、颜色、大小)的字符串组成。如以下代码就是产生一个字体为HELVETICA、大小为…

【OAI】UERANSIM容器与OAI核心网分立部署及测试

说明启动核心网:启动基站:功能测试ueransim测试1:通过12.1.1.x ping192.168.70.1ueransim测试2: 通过nr-binder绑定自定义TCP程序传数据到核心网ueransim测试3:多ueransim启动 结论附录基站配置文件:TCP通信…

HCIA-RS实验-路由配置-静态路由缺省路由

在计算机网络中,路由器是实现数据包转发的重要设备。它通过查找路由表中的路由信息,将数据包从源地址转发到目标地址。而静态路由和缺省路由则是路由表中的两种重要信息,下面我们来详细了解一下它们的概念、特点和应用。 目录 简述 一、静态…

Let‘s Learn .NET|通过 Semantic Kernel .NET SDK 管理你的 OpenAI 项目

编辑:Alan Wang 排版:Rani Sun Lets Learn .NET 系列 “Lets Learn .NET” 是面向全球的 .NET 初学者学习系列,旨在通过不同语言,帮助不同地区的开发者掌握最新的 .NET 开发知识与技能。 在 ChatGPT 与 OpenAI 火热的当下&#x…

雪花算法

雪花算法(SnowFlake),是Twitter开源 的分布式ID生成算法 主要是由 64bit 的 long 型生成的全局 ID, 其中分为四个部分: ① 最高1位固定值 0,因为生成的 id 是正整数 ② 后面的41位存储毫秒级时间戳 ③ 第三部分的10位存储机器码…

tp6.1 bingher/ueditor(百度编辑器)(七牛、阿里OSS第三方云)详情图文教程(第二版)

之前做过一版:tp6 bingher/ueditor(百度编辑器)(七牛、阿里OSS第三方云)详情图文教程_我是高手高手高高手的博客-CSDN博客 登录权限是Session,现在系统是Cookie加jwt的Token方式验证 一、修改验证登录权限 修改文件: vendor\bingher\uedito…

R语言 | 向量对象运算

目录 一、数值型的向量对象 1.1 建立规则型的数值向量对象使用序列符号 1.2 简单向量对象的运算 1.3 建立向量对象:seq()函数 1.4 连接向量对象:c()函数 1.5 重复向量对象:rep()函数 1.6 numeric()函数 1.7 程序语句短语跨行的处理 …

阶段式软件研发项目管理工具

下面这个场景是是阶段式软件研发场景,适用于采用瀑布模式开展软件研发的企业或者团队。 创建项目 新建项目时,使用“阶段式软件开发项目”项目模板创建项目。 系统会自动创建10个阶段看板(一个阶段一个看板),1个缺陷…

libgo 流程分析(1)

libgo 基础模块 libgo逻辑结构 libgo主要的功能模块主要包括:调度器( Scheduler )、处理器( Processer )、协程( Task )和一个FastSteadyClock。 其中 Scheduler -> Processer -> Task 三层逻辑结构实现了对协程( Task )的生命周期管理和调度和运行。 sch…

【好书分享】数字信号处理入门宝典(Digital Signal Processing-A Student Guide)

简介 该书作为初学者的入门书籍,葵花宝典级的存在,发行量很少,在市面上很难见到,仅此一本,想要的私信! Digital signal processing (DSP) systems have developed at a rapid pace over the past two dec…

基于DSP+FPGA+ADS1282支持31Bit高精度数据采集方案(二)模拟电路设计

如图 4.1 所示是系统硬件系统的信号框图,数字信号处理板上的主要核心是 两个处理芯片,即 FPGA 和 DSP ,其中 FPGA 主要作用是做 DSP 和外围接口的 桥梁及数据预处理, DSP 做为数据解算核心。 FPGA 通过各种的数据总…

AJAX和JSON

1、什么是AJAX? AJAX(ASynchronous JavaScript And XML)异步的JavaScript 和 XML; 由Jesse James Garrett 在他的文章AJAX:A New Approoch to Web Applications中首次提出。 ajax(Web数据交互方式)_百…

[深度学习][CenterFusion]关于centerfusion训练注意的要点

我参考博客CenterFusion 项目超详细环境搭建步骤及可视化操作_centernet可视化_上班摸不了鱼的博客-CSDN博客本文引用 CenterFusion: Center-based Radar and Camera Fusion for 3D Object Detection,复现此论文中的代码,互相学习。注意:由于…

电影元素主题:《黑客帝国》中的js加密与解密

在《黑客帝国》中,加密和解密是非常重要的概念。加密是将信息转换为看起来毫无意义的数据,以确保只有拥有解密密钥的人才能读取和理解它。在这篇文章中,我们将探讨如何使用JavaScript进行加密和解密,就像黑客们在电影中所做的那样…

2023-04-27:用go语言重写ffmpeg的remuxing.c示例。

2023-04-27:用go语言重写ffmpeg的remuxing.c示例。 答案2023-04-27: ffmpeg的remuxing.c是一个用于将多媒体文件从一种容器格式转换为另一种容器格式的命令行工具。它可以将音频、视频和字幕等元素从源文件中提取出来,并按照用户指定的方式…