『MySQL快速上手』-⑤-数据类型

文章目录

  • 1.数据类型有哪些
  • 2.数值类型
    • 2.1 tinyint 类型
    • 2.2 bit 类型
    • 2.3 小数类型
      • 2.3.1 float
      • 2.3.2 decimal
  • 3.字符串类型
    • 3.1 char
    • 3.2 varchar
    • 3.2 char 和 varchar 比较
  • 4.日期和时间类型
  • 5.enum和set

在这里插入图片描述

1.数据类型有哪些

MySQL支持多种数据类型,这些数据类型可用于定义表中的列,以存储不同类型的数据。以下是一些常见的MySQL数据类型:

整数类型

  • TINYINT:范围从-128到127(有符号)或0到255(无符号)。
  • SMALLINT:范围从-32,768到32,767(有符号)或0到65,535(无符号)。
  • MEDIUMINT:范围从-8,388,608到8,388,607(有符号)或0到16,777,215(无符号)。
  • INT或INTEGER:范围从-2,147,483,648到2,147,483,647(有符号)或0到4,294,967,295(无符号)。
  • BIGINT:范围从-9,223,372,036,854,775,808到9,223,372,036,854,775,807(有符号)或0到18,446,744,073,709,551,615(无符号)。

浮点数和定点数类型

  • FLOAT:单精度浮点数。
  • DOUBLE:双精度浮点数。
  • DECIMAL(或NUMERIC):精确的定点数,可以指定小数点位数。

字符串类型

  • CHAR:固定长度字符串,最多255个字符。
  • VARCHAR:可变长度字符串,最多65535个字符。
  • TEXT:用于存储较长文本数据。
  • BLOB:用于存储二进制数据。

日期和时间类型

  • DATE:仅包含日期。
  • TIME:仅包含时间。
  • DATETIME:包含日期和时间。
  • TIMESTAMP:包含日期和时间,通常用于存储记录的修改时间。
  • YEAR:用于存储年份。

枚举和集合类型

  • ENUM:用于存储一个从预定义值列表中选择的一个值。
  • SET:用于存储从预定义值列表中选择的零个或多个值。

空间数据类型

  • GEOMETRY:用于存储地理空间数据。
  • POINT:用于存储一个点的坐标。

这只是MySQL支持的一些常见数据类型,实际上还有其他一些数据类型和其它属性,用于满足不同数据存储需求。选择适当的数据类型对于数据库设计和性能至关重要,因此在创建数据库表时需要仔细考虑。

2.数值类型

在这里插入图片描述

2.1 tinyint 类型

数值越测试

  • 新建一个表;
create table numbers_1(num tinyint);

注意:在没有指定tinyint是否为有符号时,默认为有符号

  • 插入数据;
insert into numbers_1 values(1);
insert into numbers_1 values(128); --越界插入,报错!

有符号的tinyint类型取值范围在(-128, 127),所以插入128时会报错。

在这里插入图片描述

说明

  • 在MySQL中,整型可以指定是有符号的和无符号的,默认是有符号的
  • 可以通过UNSIGNED来说明某个字段是无符号的

案例——无符号

mysql> create table numbers_2(num tinyint unsigned);
Query OK, 0 rows affected (0.02 sec)mysql> insert into numbers_2 values(-1); -- 插入越界,报错!
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> insert into numbers_2 values(255);
Query OK, 1 row affected (0.00 sec)mysql> select * from numbers_2;
+------+
| num  |
+------+
|  255 |
+------+
1 row in set (0.00 sec)

2.2 bit 类型

基本语法:

bit[(M)] : 位字段类型。M表示每个值的位数,范围从164/
如果M被忽略,默认为1

案例

  • 创建新表;
create table numbers_3( id int, a bit(8) );
  • 插入数据;
insert into numbers_3 values (10,10);
  • 查询数据;
select * from numbers_3;

在这里插入图片描述

这时我们会发现一个很奇怪的现象,a 的数据10没有出现;

bit使用的注意事项

  • bit字段在显示时,是按照ASCII码对应的值显示

例如:

insert into numbers_3 values (65,65);
select * from numbers_3;

在这里插入图片描述

  • 如果我们有这样的值,只存放0或1,这时可以定义bit(1)。这样可以节省空间;

例如:

create table numbers_4(gender bit(1));
insert into numbers_4 values (0);
insert into numbers_4 values (1);
insert into numbers_4 values (2); --插入2时会发生越界,报错!

2.3 小数类型

2.3.1 float

语法:

float[(m, d)] [unsigned] : M指定显示长度,d指定小数位数,占用空间4个字节

案例——有符号

  • float(4,2)表示的范围是-99.99 ~ 99.99,MySQL在保存值时会进行四舍五入
create table numbers_5( id int, salary float(4,2) );
insert into numbers_5 values (100,-99.99);
insert into numbers_5 values (100,-99.992); # 2被截断
insert into numbers_5 values (100,99.95);
select * from numbers_5;

在这里插入图片描述

  • float(4,2)如果是一个有符号的,则表示范围是(-99.99, 99.99)。同理float(6,3)如果是一个有符号的,则表示范围应该是(-999.999, 999.999)float(8,3)如果是一个有符号的,则表示范围应该是(-99999.999, 99999.999)

案例——无符号

  • 如果定义的是float(4,2) unsigned 这时,因为把它指定为无符号的数,范围是 0 ~ 99.99
create table numbers_7( id int, salary float(4,2) unsigned);
insert into numbers_7 values (100,99.99);
insert into numbers_7 values (100,-0);
insert into numbers_7 values (100,-1); -- 越界,报错!
select * from numbers_7;

在这里插入图片描述

2.3.2 decimal

语法:

decimal(m, d) [unsigned] : 定点数m指定长度,d表示小数点的位数
  • decimal(5,2) 表示的范围是 -999.99 ~ 999.99;
  • decimal(5,2) unsigned 表示的范围 0 ~ 999.99;
  • decimal和float很像,但是有区别:
    • float和decimal表示的精度不一样;

案例——float、decimal对比

create table numbers_8(id int, salary float(10,8), salary2 decimal(10,8));
insert into numbers_8 values (100, 23.12345612, 23.12345612);
select * from numbers_8;

在这里插入图片描述

  • 经过对比我们发现,decimal的精度更准确,因此如果我们希望某 个数据表示高精度,选择decimal

说明:

  • float表示的精度大约是7位
  • decimal整数最大位数m为65。支持小数最大位数d是30。如果d被省略,默认为0.如果m被省略,默认是10。

3.字符串类型

3.1 char

语法:

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

案例

create table char_1(id int, name char(2));
insert into char_1 values (100,'ab');
insert into char_1 values (101,'中国');
select * from char_1;

在这里插入图片描述
说明:

  • char(2) 表示可以存放两个字符,可以是字母或汉字,但是不能超过2个, 最多只能是255

3.2 varchar

语法:

varchar(L): 可变长度字符串,L表示字符长度,最大长度65535个字节

案例

create table char_2(id int, name varchar(6));
insert into char_2 values (100,'hello');
insert into char_2 values (101,'我爱你中国');
select * from char_2;

在这里插入图片描述

说明:

关于varchar(len),len到底是多大,这个len值,和表的编码密切相关:

  • varchar长度可以指定为0到65535之间的值,但是有1 - 3 个字节用于记录数据大小,所以说有效字节数是65532
  • 当我们的表的编码是utf8时,varchar(n)的参数n最大值是65532/3=21844(因为utf中,一个字符占用3个字节);(但是在我自己的机器上测试的结果是最大值为21842
  • 如果编码是gbk,varchar(n)的参数n最大是65532/2=32766(因为gbk中,一个字符占用2字节)。(但是在我自己的机器上测试的结果是最大值为32764

案例

create table char_3(id int, name varchar(21843)) charset=utf8;
ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. 
This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBsmysql> create table char_3(id int, name varchar(21840)) charset=utf8;
Query OK, 0 rows affected (0.01 sec)
create table char_7(id int, name varchar(32765)) charset=gbk;
ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. 
This includes storage overhead, check the manual. You have to change some columns to TEXT or BLOBsmysql> create table char_7(id int, name varchar(32764)) charset=gbk;
Query OK, 0 rows affected (0.02 sec)

3.2 char 和 varchar 比较

在这里插入图片描述

CHARVARCHAR 都是用于存储字符数据的MySQL数据类型,但它们之间有一些关键区别。下面是它们之间的对比以及如何选择其中之一的一些建议:

  1. 存储方式:

    • CHAR 存储固定长度的字符串,这意味着它将始终占用指定的存储空间,无论实际存储的字符串长度如何。
    • VARCHAR 存储可变长度的字符串,根据实际存储的数据来动态分配存储空间。它只占用足够的空间来存储实际的数据,因此在存储短字符串时会更加节省空间。
  2. 存储空间效率:

    • CHAR 通常会占用更多的存储空间,因为它固定使用指定的字符数。如果你有一个CHAR(100)列,即使只存储一个字符,它也会占用100个字符的存储空间。
    • VARCHAR 通常在存储短字符串时更加节省空间,因为它只占用实际数据所需的存储空间。
  3. 查询性能:

    • CHAR 可以在某些情况下具有更快的查询性能,因为数据长度是固定的,MySQL可以更容易地进行优化。这可能在一些特定的查询场景下有所帮助。
    • VARCHAR 在存储和检索可变长度字符串时更加灵活。它通常用于存储文本、评论和描述等内容,因为这些数据通常具有不同的长度。
  4. 如何选择:

    • 使用 CHAR

      • 当你知道数据的长度是固定的,并且所有值都将具有相同的字符数时,CHAR 可能是一个不错的选择,因为它可以提供一些性能优势。
      • 例如,存储国家/地区的两个字母缩写时,使用 CHAR(2) 可能更合适。
    • 使用 VARCHAR

      • 当你处理可变长度的字符串,例如文章、评论、用户名等,或者当数据长度相对较短时,VARCHAR 更为适用。
      • 对于大多数文本数据,VARCHAR 更常见,因为它更节省存储空间。
      • 选择 VARCHAR 还可以在数据库表的设计上更加灵活,因为它可以适应不同长度的数据。

总的来说,你的选择应该取决于你的具体需求。如果你需要存储可变长度的字符串,通常情况下会选择 VARCHAR。如果你有明确的固定长度需求,可以使用 CHAR,但请注意它可能会浪费存储空间。综合考虑性能、存储需求和数据特点来选择合适的数据类型。

4.日期和时间类型

常用的日期有如下三个:

  • date:日期 ‘yyyy-mm-dd’ ,占用三字节;
  • datetime:时间日期格式 ‘yyyy-mm-dd HH:ii:ss’ 表示范围从 1000 到 9999 ,占用八字节;
  • timestamp:时间戳,从1970年开始的 yyyy-mm-dd HH:ii:ss 格式和 datetime 完全一致,占用四字节;

案例

  • 创建新表;
create table birthday (t1 date, t2 datetime, t3 timestamp);
  • 插入数据;
insert into birthday(t1, t2) values ('2003-03-01', '2023-11-08 12:34:56'); -- 插入两种时间
  • 添加数据时,时间戳自动补上当前时间;
select * from birthday;

在这里插入图片描述

  • 更新数据;
update birthday set t1='2000-01-01';
select * from birthday;

在这里插入图片描述

5.enum和set

语法:

enum: 枚举,“单选”类型;
enum('选项1','选项2','选项3',...);

该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,3,…最多65535个;当我们添加枚举值时,也可以添加对应的数字编号。

set: 集合,“多选”类型;
set('选项值1','选项值2','选项值3', ...);

该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,…最多64个。

注意:

  • 不建议在添加枚举值,集合值的时候采用数字的方式,因为不利于阅读

案例1

有一个调查表votes,需要调查人的喜好, 比如(登山,游泳,篮球,武术)中去选择(可以多选),(男,女)[单选]。

  • 创建新表;
mysql> create table votes(-> username varchar(30),-> hobby set('登山','游泳','篮球','武术'),--注意:使用数字标识每个爱好的时候,采用比特位位置来个set中的爱好对应起来-> gender enum('男','女'));--注意:使用数字标识的时候,就是正常的数组下标
  • 插入数据;
insert into votes values ('Mark','登山,武术','男');
insert into votes values ('Jimmy','游泳,篮球','2');
select * from votes;

在这里插入图片描述

select * from votes where gender=2;

在这里插入图片描述

案例2

有如下数据,想查找所有喜欢登山的人:

在这里插入图片描述
使用如下查询语句:

select * from votes where hobby='登山';

在这里插入图片描述
如图所示,并不能查询出所有爱好为登山的人。

集合查询使用find_ in_ set函数:

  • find_in_set(sub,str_list) :如果 sub 在 str_list 中,则返回下标;如果不在,返回0;str_list 用逗号分隔的字符串。

示例

mysql> select find_in_set ('a','a,b,c');
+---------------------------+
| find_in_set ('a','a,b,c') |
+---------------------------+
|                         1 |
+---------------------------+
1 row in set (0.00 sec)mysql> select find_in_set ('d','a,b,c');
+---------------------------+
| find_in_set ('d','a,b,c') |
+---------------------------+
|                         0 |
+---------------------------+
1 row in set (0.00 sec)

所以正确查询爱好登山的人的语句为:

select * from votes where find_in_set ('登山',hobby);

在这里插入图片描述

在这里插入图片描述

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

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

相关文章

【AntDesign】Docker部署

docker部署是主流的部署方式,极大的方便了开发部署环境,保持了环境的统一,也是实现自动化部署的前提。 1 项目的目录结构 dist: 使用build打包命令,生成的打包目录 npm run build : 打包项目命令 docker: 存放docker容器需要修改…

Python爬虫-获取汽车之家车家号

前言 本文是该专栏的第9篇,后面会持续分享python爬虫案例干货,记得关注。 地址:aHR0cHM6Ly9jaGVqaWFoYW8uYXV0b2hvbWUuY29tLmNuL0F1dGhvcnMjcHZhcmVhaWQ9MjgwODEwNA== 需求:获取汽车之家车家号数据 笔者将在正文中介绍详细的思路以及采集方法,废话不多说,跟着笔者直接往…

MCU系统的调试技巧

MCU系统的调试技巧对于确保系统稳定性和性能至关重要。无论是在嵌入式系统开发的初期阶段还是在产品维护和优化的过程中,有效的调试技巧可以帮助开发人员快速发现和解决问题,本文将讨论一些MCU系统调试的技巧。 首先,使用调试工具是非常重要…

[量化投资-学习笔记008]Python+TDengine从零开始搭建量化分析平台-CCI和ATR

目录 1. 指标简介CCIATR 2. 程序编写题外话 1. 指标简介 将这两个指标放在一起,一方面是因为这两个指标都属于摆动指数,可以反应市场的活跃度。 另一方面是因为CCI和ATR与之前提到的EMA,MACD,布林带的三个指标的计算基础不同。之前的三个指标都是以收盘…

AR眼镜硬件解决方案_AR/VR智能眼镜安卓主板芯片方案介绍

随着近两年来增强现实(AR)技术的逐渐成熟,采用MT8788芯片解决方案的AR眼镜已经问世。众所周知,AR技术可以帮助开发者打造一个既强大而又实用的混合现实世界,将虚拟与真实世界相结合。 据了解,MT8788芯片采用了多芯片分布式处理系统…

虚幻5.3打包Windows失败

缺失UnrealGame二进制文件。 必须使用集成开发环境编译该UE项目。或者借助虚幻编译工具使用命令行命令进行编译 解决办法: 1.依次点击平台-项目启动程序 2.点击后面的按钮进行设置 3.稍等后,打包后的程序即可运行,之后就可以愉快的打包了

支持向量机 (SVM):初学者指南

照片由 Unsplash上的 vackground.com提供 一、说明 SVM(支持向量机)简单而优雅用于分类和回归的监督机器学习方法。该算法试图找到一个超平面,将数据分为不同的类,并具有尽可能最大的边距。本篇我们将介绍如果最大边距不存在的时候…

Android修行手册-实现利用POI将图片插入到Excel中(文末送书)

点击跳转>Unity3D特效百例点击跳转>案例项目实战源码点击跳转>游戏脚本-辅助自动化点击跳转>Android控件全解手册点击跳转>Scratch编程案例点击跳转>软考全系列 👉关于作者 专注于Android/Unity和各种游戏开发技巧,以及各种资源分享&…

ZZ308 物联网应用与服务赛题第G套

2023年全国职业院校技能大赛 中职组 物联网应用与服务 任 务 书 (G卷) 赛位号:______________ 竞赛须知 一、注意事项 1.检查硬件设备、电脑设备是否正常。检查竞赛所需的各项设备、软件和竞赛材料等; 2.竞赛任务中所使用…

lsky Pci-go nas个人图床搭建

①安装PicGo 应用 http://192.168.50.249:18189/api/v1 上传电脑需要有node 和 npm环境,官网下载最新安装板node后,自动会配置npm环境。 ②安装 Lsky-Uploader 获取token: http://www.metools.info/code/post278.html 服务器域名为 Lsky p…

UICollectionView左上对齐布局

最近完成的项目需要左上对齐的瀑布流,每个格子的尺寸不同,可以使用UICollectionView定义不同的尺寸,但是CollectionView的格子高度是相同的,我想要的是这样 左上对齐分别是0、1、2;3、4; 当前只能自定义一个…

OpenCV 输出文本

PutText() 输出文本 OpenCV5 将支持中文字符的输出, 当前版本OpenCV4原生不支持, 可以使用Contrib包FreeType方式实现, 不过比较麻烦.为了省事, 也可以通过将Mat转成bitmap,然后使用GDI方式输出中文字符. 示例代码 /// <summary>/// OpenCV暂时不能支持中文字符输出,显示…

Node.js中的回调地狱

聚沙成塔每天进步一点点 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 欢迎来到前端入门之旅&#xff01;感兴趣的可以订阅本专栏哦&#xff01;这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造的。无论你是完全的新手还是有一些基础的开发…

JAVA将List转成Tree树形结构数据和深度优先遍历

引言&#xff1a; 在日常开发中&#xff0c;我们经常会遇到需要将数据库中返回的数据转成树形结构的数据返回&#xff0c;或者需要对转为树结构后的数据绑定层级关系再返回&#xff0c;比如需要统计当前节点下有多少个节点等&#xff0c;因此我们需要封装一个ListToTree的工具类…

Python 海龟绘图基础教学教案(二十六)

Python 海龟绘图——第 49 题 题目&#xff1a;绘制下面的图形 解析&#xff1a; 使用二重循环绘制六叶长方形风车。 答案&#xff1a; Python 海龟绘图——第 50 题 题目&#xff1a;绘制下面的图形 解析&#xff1a;使用二重循环绘制由四个相同大小菱形组成的四叶风车图案…

opengauss权限需求

创建角色 "u_rts" 并授予对数据库 "rts_opsdb" 的只读权限&#xff1a; CREATE ROLE u_rts LOGIN PASSWORD Cloud1234; GRANT CONNECT ON DATABASE rts_opsdb TO u_rts; GRANT USAGE ON SCHEMA public TO u_rts; GRANT SELECT ON ALL TABLES IN SCHEMA pub…

STM32MPU6050角度的读取(STM32驱动MPU6050)

注&#xff1a;文末附STM32驱动MPU6050代码工程链接&#xff0c;需要的读者请自取。 一、MPU6050介绍 MPU6050是一款集成了三轴陀螺仪和三轴加速度计的传感器芯片&#xff0c;由英国飞利浦半导体&#xff08;现为恩智浦半导体&#xff09;公司生产。它通过电子接口&#xff08…

多测师肖sir_高级金牌讲师_jenkins搭建

jenkins操作手册 一、jenkins介绍 1、持续集成&#xff08;CI&#xff09; Continuous integration 持续集成 团队开发成员每天都有集成他们的工作&#xff0c;通过每个成员每天至少集成一次&#xff0c;也就意味着一天有可 能多次集成。在工作中我们引入持续集成&#xff0c;通…

大模型时代,开发者成长指南 | 新程序员

【编者按】GPT 系列的面世影响了全世界、各个行业&#xff0c;对于开发者们的感受则最为深切。以 ChatGPT、Github Copilot 为首&#xff0c;各类 AI 编程助手层出不穷。编程范式正在发生前所未有的变化&#xff0c;从汇编到 Java 等高级语言&#xff0c;再到今天以自然语言为特…

Python高级语法----Python多线程与多进程

文章目录 多线程多进程注意事项多线程与多进程是提高程序性能的两种常见方法。在深入代码之前,让我们先用一个简单的比喻来理解它们。 想象你在一家餐厅里工作。如果你是一个服务员,同时负责多个桌子的顾客,这就类似于“多线程”——同一个人(程序)同时进行多项任务(线程…