MySQL 从零开始:05 MySQL 数据类型

文章目录

  • 1、数值类型
    • 1.1 整形数值
    • 1.2 浮点型数值
    • 1.3 布尔值
  • 2、日期和时间类型
  • 3、字符串类型
    • 3.1 CHAR 和 VARCHAR
    • 3.2 BINARY 和 VARBINARY
    • 3.3 BLOB 和 TEXT
    • 3.4 ENUM 类型
    • 3.5 SET 类型
  • 4、空间数据类型
  • 5、JSON 数据类型
  • 5、JSON 数据类型

前面的讲解中已经接触到了表的创建, 表的创建是对字段的声明,比如:

mysql> create table class(-> id int primary key auto_increment,-> name varchar(10) not null default '',-> gender char(1) not null default '',-> company varchar(20) not null default '',-> salary decimal(6,2) not null default 0.00-> )engine myisam charset utf8;

上述语句声明了字段的名称、类型、所占空间、默认值 和是否可以为空等信息。其中的 intvarcharchardecimal 都是 MySQL 所支持的数据类型,本节将详细介绍 MySQL 支持的数据类型。

MySQL 中定义数据字段的类型对数据库的优化非常重要。MySQL中的每种数据类型都可以通过以下特征来确定:

  • 它用来表示数据值。
  • 占用的空间以及值是固定长度还是可变长度。
  • 数据类型的值可以被索引。
  • MySQL如何比较特定数据类型的值。

MySQL 支持的数据类型可以分为三类:数值日期/时间字符串(字符)类型,另外还有空间数据类型JSON数据类型,本节以前三种数据类型为主,最后两种简单介绍一下。

1、数值类型

MySQL支持所有标准SQL数值数据类型。

这些类型包括严格数值数据类型(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及近似数值数据类型(FLOAT、REAL和DOUBLE PRECISION)。

关键字INT是INTEGER的同义词,关键字DEC是DECIMAL的同义词。

作为SQL标准的扩展,MySQL也支持整数类型TINYINT、MEDIUMINT和BIGINT。下面的表显示了需要的每个整数类型的存储和范围。

类型大小范围(有符号)范围(无符号)用途
TINYINT1 字节(-128,127)(0,255)小整数值
SMALLINT2 字节(-32 768,32 767)(0,65 535)大整数值
MEDIUMINT3 字节(-8 388 608,8 388 607)(0,16 777 215)大整数值
INT或INTEGER4 字节(-2 147 483 648,2 147 483 647)(0,4 294 967 295)大整数值
BIGINT8 字节(-9 233 372 036 854 775 808,9 223 372 036 854 775 807)(0,18 446 744 073 709 551 615)极大整数值
FLOAT4 字节(-3.402 823 466 E+38,1.175 494 351 E-38),0,(1.175 494 351 E-38,3.402 823 466 351 E+38)0,(1.175 494 351 E-38,3.402 823 466 E+38)单精度 浮点数值
DOUBLE8 字节(1.797 693 134 862 315 7 E+308,2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308)0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308)双精度 浮点数值
DECIMAL对DECIMAL(M,D) ,如果M>D,为M+2否则为D+2依赖于M和D的值依赖于M和D的值小数值

1.1 整形数值

以 TINYINT 为例详细介绍整形数值型的一些属性及操作。

TINYINT[(M)][UNSIGNED][ZEROFILL]

M表示每个值的位数,此处为显示的位数,并不是占用字节大小。该可选显示宽度规定用于显示宽度小于指定的列宽度的值时从左侧填满宽度。当结合可选扩展属性ZEROFILL使用时, 默认补充的空格用零代替。例如,对于声明为INT(5) ZEROFILL的列,值5检索为00005。

注意:M 要与 ZEROFILL 配合使用才有效果。

如果一个数值列指定为 ZEROFILL, MySQL自动为该列添加 UNSIGNED 属性。

mysql> create database datatype;
Query OK, 1 row affected (0.03 sec)mysql> use datatype;
Database changed
mysql> show tables;
Empty set (0.00 sec)mysql> create table int_type(-> id TINYINT not null default 0,-> age TINYINT(4) not null default 0,-> distance TINYINT(4) ZEROFILL not null default 0,-> score TINYINT UNSIGNED not null default 0,-> ranking TINYINT ZEROFILL not null default 0-> )engine myisam charset utf8;
Query OK, 0 rows affected, 1 warning (0.06 sec)mysql> desc int_type;
+----------+------------------------------+------+-----+---------+-------+
| Field    | Type                         | Null | Key | Default | Extra |
+----------+------------------------------+------+-----+---------+-------+
| id       | tinyint(4)                   | NO   |     | 0       |       |
| age      | tinyint(4)                   | NO   |     | 0       |       |
| distance | tinyint(4) unsigned zerofill | NO   |     | 0000    |       |
| score    | tinyint(3) unsigned          | NO   |     | 0       |       |
| ranking  | tinyint(3) unsigned zerofill | NO   |     | 000     |       |
+----------+------------------------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

1.2 浮点型数值

对于浮点列类型,在MySQL中单精度值使用4个字节,双精度值使用8个字节。

DOUBLE[(M,D)][UNSIGNED][ZEROFILL]

  • M:精度,代表“总位数”;
  • D:标度,代表小数位(小数点右边的位数)

1.3 布尔值

MySQL 没有内置的 BOOLEANBOOL 数据类型,使用最小的整数类型,也就是 TINYINT(1) 来表示。

2、日期和时间类型

表示时间值的日期和时间类型为 DATETIMEDATETIMESTAMPTIMEYEAR

每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。

TIMESTAMP 类型有专有的自动更新特性,将在后面描述。

类型大小 (字节)范围格式描述
DATE31000-01-01/9999-12-31YYYY-MM-DD日期值
TIME3‘-838:59:59’/‘838:59:59’HH:MM:SS时间值或持续时间
YEAR11901/2155YYYY年份值
DATETIME81000-01-01 00:00:00/9999-12-31 23:59:59YYYY-MM-DD HH:MM:SS混合日期和时间值
TIMESTAMP41970-01-01 00:00:00/2038结束时间是第 2147483647 秒,北京时间 2038-1-19 11:14:07,格林尼治时间 2038年1月19日 凌晨 03:14:07YYYYMMDD HHMMSS混合日期和时间值,时间戳

注意:

  • 包含两位数年份值的日期是不明确的,因为世纪是未知的,MySQL 使用如下规则解释两位数的年份值:
    • 年份值在7099之间转换为19701999
    • 年份值在0069之间转换为20002069
  • 通过连接器/ODBC使用的“零”值日期或时间值将自动转换为NULL,因为ODBC无法处理这些值。

3、字符串类型

在MySQL中,字符串可以容纳从纯文本到二进制数据(如图像或文件)的任何内容。 字符串类型指 CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET。

类型大小描述
CHAR0-255字节定长字符串
VARCHAR0-65535 字节变长字符串
TINYBLOB0-255字节不超过 255 个字符的二进制字符串
TINYTEXT0-255字节短文本字符串
BLOB0-65 535字节二进制形式的长文本数据
TEXT0-65 535字节长文本数据
MEDIUMBLOB0-16 777 215字节二进制形式的中等长度文本数据
MEDIUMTEXT0-16 777 215字节中等长度文本数据
LONGBLOB0-4 294 967 295字节二进制形式的极大文本数据
LONGTEXT0-4 294 967 295字节极大文本数据

3.1 CHAR 和 VARCHAR

CHAR 和 VARCHAR 类型类似,但它们保存检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。

CHAR和VARCHAR类型声明时需要一个长度值,该值表示你想要想要存储的字符的最大数量。例如,CHAR(30)可以容纳30个字符。 CHAR 列的宽度在创建表时已经固定下来了,如果插入记录该字段的宽度不足指定宽度,那么要在右侧自动填补 空格。检索CHAR值时,除非启用 PAD_CHAR_TO_FULL_LENGTH SQL模式,否则将删除尾部空格。

存储 VARCHAR 值时,不会填充。在与标准SQL一致的情况下,存储和检索值时保留尾部空格。

下表展示了CHAR和VARCHAR之间的差异,它展示了将各种字符串值存储到CHAR(4)和VARCHAR(4)列的结果(假设此列使用了一个单字节字符集,如latin1)。

ValueCHAR(4)Storage RequiredVARCHAR(4)Storage Required
''' '4 bytes''1 byte
'ab''ab '4 bytes'ab'3 bytes
'abcd''abcd'4 bytes'abcd'5 bytes
'abcdefgh''abcd'4 bytes'abcd'5 bytes

请看下面例子:

01.vchar_varchar

3.2 BINARY 和 VARBINARY

BINARY 和 VARBINARY 类似于 CHAR 和 VARCHAR,不同的是它们包含二进制字符串而不要非二进制字符串。也就是说,它们包含字节字符串而不是字符字符串。这说明它们没有字符集,并且排序和比较基于列值字节的数值。

3.3 BLOB 和 TEXT

BLOB 是一个二进制大对象,可以容纳可变数量的数据。有 4 种 BLOB 类型:TINYBLOB、BLOB、MEDIUMBLOB 和 LONGBLOB。它们区别在于可容纳存储范围不同。四种 TEXT 类型是TINYTEXT、TEXT、MEDIUMTEXT 和 LONGTEXT。它们对应于四个 BLOB 类型,并且具有相同的最大长度和存储要求。

3.4 ENUM 类型

ENUM 是一个字符串对象,它从一个允许值列表中选择了一个值,这些值在表创建时显式地列出了列规范中。它有这些优势:

  • 在一列有有限的可能值集合的情况下,压缩数据存储。你指定为输入值的字符串被自动编码为数字。
  • 可读的查询和输出。在查询结果中,这些数字被转换回相应的字符串。

枚举值必须是引用的字符串文字。 你可以这样用枚举列创建表:

mysql> create table shirts (-> name varchar(40),-> size enum('x-small', 'small', 'medium', 'large')-> );
Query OK, 0 rows affected (0.10 sec)mysql> insert into shirts -> (name, size)-> values -> ('dress shirt', 'large'),-> ('t-shirt', 'medium'),-> ('polo shirt', 'small');
Query OK, 3 rows affected (0.04 sec)
Records: 3  Duplicates: 0  Warnings: 0mysql> select name, size from shirts where size = 'large';
+-------------+-------+
| name        | size  |
+-------------+-------+
| dress shirt | large |
+-------------+-------+
1 row in set (0.00 sec)

假如向该表中插入一百万条 值为 'medium' 的记录,存储空间需要一百万字节。相比而言,如果以字符串 'medium' 存储,则需要六百万字节。

3.5 SET 类型

SET 是一个字符串对象,可以有0个或多个值,并且每一个值都必须从表创建时指定的允许值列表中选择。SET 的列值由多个集合成员组成的,用逗号(,)分隔。这样的话,SET成员值本身不应该包含逗号。

例如,由 SET('one', 'two') NOT NULL 指定的数据列可以有这些值:

''
'one'
'two'
'one,two'

SET 列最多可以包含64个不同的成员。

看如下例子:

mysql> INSERT INTO myset (col) VALUES -> ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');
Query OK, 5 rows affected (0.09 sec)
Records: 5  Duplicates: 0  Warnings: 0mysql> select col from myset;
+------+
| col  |
+------+
| a,d  |
| a,d  |
| a,d  |
| a,d  |
| a,d  |
+------+
5 rows in set (0.00 sec)

从查询结果可以看出:如果一条记录里已经包含 SET 的一个成员了,就不会重复保存该值。

4、空间数据类型

MySQL支持许多包含各种几何和地理值的空间数据类型,如下表所示:

类型描述
GEOMETRY任何类型的空间值
POINT一个点(一对X-Y坐标)
LINESTRING曲线(一个或多个POINT值)
POLYGON多边形
GEOMETRYCOLLECTIONGEOMETRY值的集合
MULTILINESTRINGLINESTRING值的集合
MULTIPOINTPOINT值的集合
MULTIPOLYGONPOLYGON值的集合

5、JSON 数据类型

MySQL 支持由 RFC 7159 规定的原生 JSON 数据类型,以更有效地存储和管理JSON文档。 本机JSON数据类型提供JSON文档的自动验证和最佳存储格式。 JSON 列不能有默认值

mysql> CREATE TABLE myjson (jdoc JSON);
Query OK, 0 rows affected (0.13 sec)mysql> INSERT INTO myjson -> VALUES -> ('{"key1": "value1", "key2": "value2"}');
Query OK, 1 row affected (0.03 sec)mysql> SELECT jdoc FROM myjson;
+--------------------------------------+
| jdoc                                 |
+--------------------------------------+
| {"key1": "value1", "key2": "value2"} |
+--------------------------------------+
1 row in set (0.00 sec)mysql> INSERT INTO myjson -> VALUES -> ('[1, 2');
ERROR 3140 (22032): Invalid JSON text: "Missing a comma or ']' after an array element." at position 5 in value for column 'myjson.jdoc'.

可以看到,如果我们插入的记录 JSON 数据格式不正确是不能成功的。

类型描述
GEOMETRY任何类型的空间值
POINT一个点(一对X-Y坐标)
LINESTRING曲线(一个或多个POINT值)
POLYGON多边形
GEOMETRYCOLLECTIONGEOMETRY值的集合
MULTILINESTRINGLINESTRING值的集合
MULTIPOINTPOINT值的集合
MULTIPOLYGONPOLYGON值的集合

5、JSON 数据类型

MySQL 支持由 RFC 7159  规定的原生 JSON 数据类型,以更有效地存储和管理JSON文档。 本机JSON数据类型提供JSON文档的自动验证和最佳存储格式。 JSON 列不能有默认值

mysql> CREATE TABLE myjson (jdoc JSON);
Query OK, 0 rows affected (0.13 sec)mysql> INSERT INTO myjson -> VALUES -> ('{"key1": "value1", "key2": "value2"}');
Query OK, 1 row affected (0.03 sec)mysql> SELECT jdoc FROM myjson;
+--------------------------------------+
| jdoc                                 |
+--------------------------------------+
| {"key1": "value1", "key2": "value2"} |
+--------------------------------------+
1 row in set (0.00 sec)mysql> INSERT INTO myjson -> VALUES -> ('[1, 2');
ERROR 3140 (22032): Invalid JSON text: "Missing a comma or ']' after an array element." at position 5 in value for column 'myjson.jdoc'.

可以看到,如果我们插入的记录 JSON 数据格式不正确是不能成功的。

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

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

相关文章

跟着cherno手搓游戏引擎【5】layer(层)

编写基类层: Layer.h:提供Attach链接、Detach解绑、Update刷新、Event事件、GetName方法 #pragma once #include"YOTO/Core.h" #include"YOTO/Event/Event.h" namespace YOTO {class YOTO_API Layer{public:Layer(const std::string& nam…

基于kkFileView实现万能文件预览

基于kkFileView实现万能文件预览 1.简介 文档在线预览项目解决方案,项目使用流行的spring boot搭建,易上手和部署。万能的文件预览开源项目,基本支持主流文档格式预览 官网:https://kkview.cn/zh-cn/docs/home.html github地址…

使用 Docker 进行 Go 应用程序引导指南

为在 Docker 中部署的 Go 应用程序做准备 在使用 Go 开发 Web 应用程序时,无论是用于 HTTP 还是其他类型的服务,部署到不同的阶段或环境(本地开发、生产环境等)都是一个常见的考虑因素。在本文中,我们将探讨在 Docker …

浅析Linux进程管理:current宏实现

本文基于Linux 5.10.186版本内核源码进行分析。 文章目录 current概述早期内核版本实现最新版本内核实现x86体系下的current宏实现ARMv8体系下的current实现 相关参考 current概述 Linux内核在运行时经常需要访问当前运行进程的task_struct指针,于是,系…

CRM-如何做好客户管理

客户是企业最重要的资源,也是客户360视图管理的主数据,企业的运转都是围绕客户来开展的,如何做好客户数据的管理是一门学问,也需要企业动态的调整战略。 客户分为企业客户(Account)与个人客户(…

NUS CS1101S:SICP JavaScript 描述:前言、序言和致谢

前言 原文:Foreword 译者:飞龙 协议:CC BY-NC-SA 4.0 我有幸在我还是学生的时候见到了了不起的 Alan Perlis,并和他交谈了几次。他和我共同深爱和尊重两种非常不同的编程语言:Lisp 和 APL。跟随他的脚步是一项艰巨的任…

大创项目推荐 深度学习疫情社交安全距离检测算法 - python opencv cnn

文章目录 0 前言1 课题背景2 实现效果3 相关技术3.1 YOLOV43.2 基于 DeepSort 算法的行人跟踪 4 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 **基于深度学习疫情社交安全距离检测算法 ** 该项目较为新颖,适合作为竞赛…

基于深度学习的婴儿啼哭识别项目详解

基于深度学习的婴儿啼哭识别项目详解 基于深度学习的婴儿啼哭识别项目详解一、项目背景1.1 项目背景1.2 数据说明 二、PaddleSpeech环境准备三、数据预处理3.1 数据解压缩3.2 查看声音文件3.3 音频文件长度处理 四、自定义数据集与模型训练4.1 自定义数据集4.2 模型训练4.3 模型…

Linux截图方法推荐

因为经常会遇到以图为证的情况,而办公设备基本都是linux,所以汇总一下常见的linux截图方式。 1:在 Linux 中系统集成的截图的默认方式 你想要截取整个屏幕?屏幕中的某个区域?某个特定的窗口? 如果只需要获取一张屏幕…

Servlet-体系结构

一、思考 读者阅读完上一篇关于Servlet基本概念的文章后,我们知道每次实现一个Servlet,都需要覆盖五个接口,我们对除service接口外的其它四个接口,我们通常不会做什么处理。那么,这种实现方式是否有些繁琐呢&#xff…

【Linux实用篇】Linux常用命令(2)

目录 1.3 拷贝移动命令 1.3.1 cp 1.3.2 mv 1.4 打包压缩命令 1.5 文本编辑命令 1.5.1 vi&vim介绍 1.5.2 vim安装 1.5.3 vim使用 1.6 查找命令 1.6.1 find 1.6.2 grep 1.3 拷贝移动命令 1.3.1 cp 作用: 用于复制文件或目录 语法: cp [-r] source dest ​ 说明: …

深入理解@DubboReference与@DubboService【三】

欢迎来到我的博客,代码的世界里,每一行都是一个故事 探索Dubbo的核心:深入理解DubboReference与DubboService【三】 前言DubboService注解基本概念使用示例高级特性 DubboReference注解基本概念使用示例服务调用流程 最佳实践注解的最佳使用方…

什么是云服务器,阿里云优势如何?

阿里云服务器ECS英文全程Elastic Compute Service,云服务器ECS是一种安全可靠、弹性可伸缩的云计算服务,阿里云提供多种云服务器ECS实例规格,如经济型e实例、通用算力型u1、ECS计算型c7、通用型g7、GPU实例等,阿里云百科aliyunbai…

Fabric2.2:在有系统通道的情况下搭建应用通道

写在最前 在使用Fabric-SDK-Go1.0.0操作Fabric网络时遇到了bug。Fabric-SDK-GO的当前版本没有办法在没有系统通道的情况下创建应用通道,而Fabric的最新几个版本允许在没有系统通道的情况下搭建应用通道。为了解决这个矛盾并使用Fabric-SDK-GO完成后续的项目开发&…

Web前端 ---- 【Vue3】ref和reactive实现响应式的区别和联系

目录 前言 setup ref 基本数据类型 对象形式 reactive ref和reactive的区别与联系 前言 本文介绍函数ref和函数reactive实现响应式 setup 在介绍ref和reactive之前,先介绍setup,vue3新引入的配置项。在该配置项中,在vue2中的data、methods、comput…

xtu oj 1475 冰墩墩和冰壶

题目描述 冰壶是被誉为“冰面上的国际象棋”,其计分规则是各自投壶,最后在大本营内,你有几个壶离圆心比对方所有壶离圆心都近就得到几分。 比如红方有两个壶,分别在坐标(1,1),(−2,1);黄方也有两个壶,分别…

GULP 案例 4:如何计算热力学性质(热容、熵、焓、自由能等)?

---------------------------------------------------------------------- 物体的热力学性质是指物质处于平衡状态下压力 P、体积 V、温度 T、组成以及其他的热力学函数之间的变化规律。一般将材料的压力 P、体积 V、温度 T、内能 U、焓 H、熵 S 等统称为物体热力学性质。 热…

软件测试|Python数据可视化神器——pyecharts教程(九)

使用pyecharts绘制K线图进阶版 简介 K线图(Kandlestick Chart),又称蜡烛图,是一种用于可视化金融市场价格走势和交易数据的图表类型。它是股票、外汇、期货等金融市场中最常用的技术分析工具之一,可以提供关于价格变…

黑马python就业课

文章目录 初级中级高级初级课程分享 初级 中级 高级 初级课程分享 链接:https://pan.baidu.com/s/1aiJHaThezv_mSI1rnV3d7g 提取码:xdpc

软件测试|Selenium StaleElementReferenceException 异常分析与解决

简介 Selenium 是一个流行的自动化测试工具,用于模拟用户与网页交互。然而,当我们在使用 Selenium 时,可能会遇到一个常见的异常,即 StaleElementReferenceException。这个异常通常在我们尝试与网页上的元素交互时抛出&#xff0…