MySQL数据库数据类型
MySQL数据库数据类型分类
在MySQL数据库中,MySQL数据类型分有四大类:数值类型、文本/二进制类型、时间日期和String类型。以下是这四大类的具体类型:
数值类型
数值类型的范围和字节大小:
tinyint类型
tinyint类型只有一个字节大小,其数据范围为:【-128,127】
有符号举例:
mysql> create table tt1( --创建表,字段只有num,类型为tinyint-> num tinyint-> );
Query OK, 0 rows affected (0.04 sec)mysql> insert into tt1 values(1); --成功
Query OK, 1 row affected (0.00 sec)mysql> insert into tt1 values(127); --成功
Query OK, 1 row affected (0.00 sec)mysql> insert into tt1 values(128); --越界
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> select * from tt1;
+------+
| num |
+------+
| 1 |
| 127 |
+------+
2 rows in set (0.00 sec)
说明:
在MySQL中,整型可以指定是有符号的和无符号的,默认是有符号的。可以通过UNSIGNED来说明某个字段是无符号的。
无符号举例:
mysql> create table tt2( --tt2表,只有num字段,类型为tinyiny unsigned,表示无符号-> num tinyint unsigned);
Query OK, 0 rows affected (0.04 sec)mysql> insert into tt2 values(-1); --数值范围在【0,255】
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> insert into tt2 values(255); --成功
Query OK, 1 row affected (0.01 sec)mysql> select * from tt2;
+------+
| num |
+------+
| 255 |
+------+
1 row in set (0.00 sec)
温馨提示:尽量不使用unsigned,对于int类型可能存放不下的数据,int unsigned同样可能存放不下,与其如此,还不如设计时,将int类型提升为bigint类型。
bit类型
基本语法:
bit[(M)] : 位字段类型。M表示每个值的位数,范围从1到64。如果M被忽略,默认为1。
举例:
mysql> create table tt3( --创建tt3表,字段有id 类型为int,a 类型为bit(8).表示有8位比特位-> id int,-> a bit(8)-> );
Query OK, 0 rows affected (0.03 sec)mysql> insert into tt3 values(10,10); --插入数据
Query OK, 1 row affected (0.00 sec)mysql> select * from tt3; --在显示的时候,会发现一个奇怪的问题,a的值没有显示
+------+------+
| id | a |
+------+------+
| 10 |
+------+------+
1 row in set (0.00 sec)
我们会发现,在查询tt3表的时候,a的值没有显示出来。原来,bit字段在显示时,是按照ASCII码对应的值显示的,比如这样子:
mysql> insert into tt3 values(65,65);
Query OK, 1 row affected (0.00 sec)mysql> select * from tt3;
+------+------+
| id | a |
+------+------+
| 10 | |
| 65 | A |
+------+------+
2 rows in set (0.00 sec)
查询出来的结果可以很清楚,65对应就是A,而10,对应的是换行键LF,因此没有显示出来。
如果我们有这样的值,只存放0或1,这时可以定义bit(1),这样可以节省空间:
mysql> create table tt4(-> gender bit(1)-> );
Query OK, 0 rows affected (0.03 sec)mysql> insert into tt4 values(0);
Query OK, 1 row affected (0.01 sec)mysql> insert into tt4 values(1);
Query OK, 1 row affected (0.01 sec)mysql> insert into tt4 values(2); --当插入2的时候报错
ERROR 1406 (22001): Data too long for column 'gender' at row 1
小数类型
float类型
语法:
float[(m, d)] [unsigned] : M指定显示长度,d指定小数位数,占用空间4个字节
举例:
小数:float(4,2)表示的范围是-99.99 ~ 99.99,MySQL在保存值时会进行四舍五入。
mysql> create table tt5(-> id int,-> salary float(4,2)-> );
Query OK, 0 rows affected (0.03 sec)mysql> insert into tt5 values(100,99.99);
Query OK, 1 row affected (0.00 sec)mysql> insert into tt5 values(101,-99.99);
Query OK, 1 row affected (0.01 sec)mysql> insert into tt5 values(102,99.991); --多的这一点被拿掉
Query OK, 1 row affected (0.00 sec)mysql> insert into tt5 values(103,-99.991);
Query OK, 1 row affected (0.00 sec)mysql> insert into tt5 values(104,-99.995); --四舍五入会失败,由于定义了长度为4,小数位为2,不能变成100.00
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> select * from tt5;
+------+--------+
| id | salary |
+------+--------+
| 100 | 99.99 |
| 101 | -99.99 |
| 102 | 99.99 |
| 103 | -99.99 |
+------+--------+
4 rows in set (0.00 sec)
如果定义的是float(4,2) unsigned 这时,因为把它指定为无符号的数,范围是:0 ~ 99.99
mysql> create table tt6(-> id int,-> salary float(4,2) unsigned);
Query OK, 0 rows affected (0.03 sec)mysql> insert into tt6 values(100,-0.1);
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> insert into tt6 values(100,-0);
Query OK, 1 row affected (0.01 sec)mysql> insert into tt6 values(100,99.99);
Query OK, 1 row affected (0.00 sec)mysql> select * from tt6;
+------+--------+
| id | salary |
+------+--------+
| 100 | 0.00 |
| 100 | 99.99 |
+------+--------+
2 rows in set (0.00 sec)
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表示的精度不一样。
mysql> create table tt7(-> id int,-> salary float(10,8),-> salary2 decimal(10,8)-> );
Query OK, 0 rows affected (0.03 sec)mysql> insert into tt7 values(100,23.12345612,12.12345612);
Query OK, 1 row affected (0.00 sec)mysql> select * from tt7; --# 发现decimal的精度更准确,因此如果我们希望某个数据表示高精度,选择decimal
+------+-------------+-------------+
| id | salary | salary2 |
+------+-------------+-------------+
| 100 | 23.12345695 | 12.12345612 |
+------+-------------+-------------+
1 row in set (0.00 sec)
说明:float表示的精度大约是7位。decimal整数最大位数m为65。支持小数最大位数d是30。如果d被省略,默认为0。如果m被省略,默认是10。因此如果希望小数的精度高,推荐使用decimal。
字符串类型
char类型
语法:
char(L): 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255
举例:
mysql> create table tt8(-> id int,-> name char(2)-> );
Query OK, 0 rows affected (0.03 sec)mysql> insert into tt8 values(100,'ab');
Query OK, 1 row affected (0.01 sec)mysql> insert into tt8 values(100,'汉族');
Query OK, 1 row affected (0.00 sec)mysql> select * from tt8;
+------+--------+
| id | name |
+------+--------+
| 100 | ab |
| 100 | 汉族 |
+------+--------+
2 rows in set (0.00 sec)
说明:
在MySQL中,char(2)可以存放两个字符,但是不能超过2个,.CHAR最多只能是char(255),不管是汉族还是字母还是什么,因为在MySQL中,一个字符就是一个字符,一个单词,一个汉字的意思。
varchar类型
语法:
varchar(L): 可变长度字符串,L表示字符长度,最大长度65535个字节
举例:
mysql> create table tt9(-> id int,-> name varchar(6)); --表示可以存放6个字符
Query OK, 0 rows affected (0.04 sec)mysql> insert into tt9 values(100,'hello');
Query OK, 1 row affected (0.00 sec)mysql> insert into tt9 values(101,'我爱你,中国');
Query OK, 1 row affected (0.01 sec)mysql> select * from tt9;
+------+--------------------+
| id | name |
+------+--------------------+
| 100 | hello |
| 101 | 我爱你,中国 |
+------+--------------------+
2 rows in set (0.00 sec)
说明:
关于varchar(len),len到底是多大,这个len值,和表的编码密切相关:varchar长度可以指定为0到65535之间的值,但是有1 - 3 个字节用于记录数据大小,所以说有效字节数是65532。
当我们的表的编码是utf8时,varchar(n)的参数n最大值是65532/3=21844[因为utf中,一个字符占
用3个字节],如果编码是gbk,varchar(n)的参数n最大是65532/2=32766(因为gbk中,一个字符占用2字节)
mysql> create table tt10(-> name varchar(21845)) charset=utf8; --验证了utf8确实是不能超过21844
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 tt10( name varchar(21844)) charset=utf8;
Query OK, 0 rows affected (0.03 sec)
char和varchar的比较
如何选择定长或变长字符串?
如果数据确定长度都一样,就使用定长(char),比如:身份证,手机号,md5。
如果数据长度有变化,就使用变长(varchar), 比如:名字,地址,但是你要保证最长的能存的进去。
定长的磁盘空间比较浪费,但是效率高。
变长的磁盘空间比较节省,但是效率低。
定长的意义是,直接开辟好对应的空间。
变长的意义是,在不超过自定义范围的情况下,用多少,开辟多少。
日期和时间类型
常用的日期有如下三个:
date日期: 'yyyy-mm-dd' ,占用三字节。
datetime时间日期格式: 'yyyy-mm-dd HH:ii:ss' 表示范围从 1000 到 9999 ,占用八字节。
timestamp时间戳:从1970年开始的 yyyy-mm-dd HH:ii:ss 格式和 datetime 完全一致,占用四字节。
举例:分别给出这三种日期时间类型的数据。
mysql> create table tt11(-> t1 date,-> t2 datetime,-> t3 timestamp);
Query OK, 0 rows affected (0.04 sec)mysql> insert into tt11(t1,t2) values('2023-8-2','2023-9-1 12:1:1'); --插入两种类型
Query OK, 1 row affected (0.01 sec)mysql> select * from tt11;
+------------+---------------------+------------------------+
| t1 | t2 | t3 |
+------------+---------------------+------------------------+
| 2023-08-02 | 2023-09-01 12:01:01 | 2023-08-02 20:56:25 | --时间戳会自动写上
+------------+---------------------+---------------------+
1 row in set (0.00 sec)
enum和set
语法:
enum:枚举,“单选”类型;enum('选项1','选项2','选项3',...);
该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,3,....最多65535个;当我们添加枚举值时,也可以添加对应的数字编号。
set:集合,“多选”类型;set('选项值1','选项值2','选项值3', ...);
该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,....最多64个。
举例:
建表:
mysql> create table votes(-> username varchar(32),-> hobby set('篮球','唱跳','武术','游泳','跑步'),--注意:使用数字标识每个爱好的时候,想想
--Linux权限,采用比特位位置来个set中的爱好对应起来-> gender enum('男','女') --注意:使用数字标识的时候,就是正常的数组下标-> );
Query OK, 0 rows affected (0.03 sec)
插入数据:
mysql> insert into votes values('张三','登山,武术','男');
ERROR 1265 (01000): Data truncated for column 'hobby' at row 1
mysql> insert into votes values('张三','跑步,武术','男');
Query OK, 1 row affected (0.01 sec)mysql> insert into votes values('Amy','游泳,唱跳','2');
Query OK, 1 row affected (0.01 sec)mysql> select * from votes;
+----------+---------------+--------+
| username | hobby | gender |
+----------+---------------+--------+
| 张三 | 武术,跑步 | 男 |
| Amy | 唱跳,游泳 | 女 |
+----------+---------------+--------+
2 rows in set (0.00 sec)mysql> insert into votes values('李四','跑步','1');
Query OK, 1 row affected (0.00 sec)mysql> insert into votes values('王五','篮球','1');
Query OK, 1 row affected (0.01 sec)mysql> insert into votes values('赵六','游泳,篮球','1');
Query OK, 1 row affected (0.00 sec)mysql> select * from votes;
+----------+---------------+--------+
| username | hobby | gender |
+----------+---------------+--------+
| 张三 | 武术,跑步 | 男 |
| Amy | 唱跳,游泳 | 女 |
| 李四 | 跑步 | 男 |
| 王五 | 篮球 | 男 |
| 赵六 | 篮球,游泳 | 男 |
+----------+---------------+--------+
5 rows in set (0.00 sec)
查找所有喜欢跑步的人:
mysql> select * from votes where hobby='跑步';
+----------+--------+--------+
| username | hobby | gender |
+----------+--------+--------+
| 李四 | 跑步 | 男 |
+----------+--------+--------+
1 row in set (0.00 sec)
不能查询出所有,爱好为跑步的人。只能查询到,单纯只有跑步的人。
集合查询使用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('z','a,b,c');
+--------------------------+
| find_in_set('z','a,b,c') |
+--------------------------+
| 0 |
+--------------------------+
1 row in set (0.00 sec)
查找所有喜欢跑步的人:
mysql> select * from votes where find_in_set('跑步',hobby);
+----------+---------------+--------+
| username | hobby | gender |
+----------+---------------+--------+
| 张三 | 武术,跑步 | 男 |
| 李四 | 跑步 | 男 |
+----------+---------------+--------+
2 rows in set (0.00 sec)
相关文章:

MySQL数据库数据类型
MySQL数据库数据类型分类 在MySQL数据库中,MySQL数据类型分有四大类:数值类型、文本/二进制类型、时间日期和String类型。以下是这四大类的具体类型: 数值类型 数值类型的范围和字节大小: tinyint类型 tinyint类型只有一个字节…...
【力扣】27. 移除元素 <快慢指针、首尾指针>
【力扣】27. 移除元素 给你一个数组 nums 和一个值 val,你需要原地移除所有数值等于 val 的元素,并返回移除后数组的新长度。不要使用额外的数组空间,必须仅使用 O(1) 额外空间并原地修改输入数组。元素的顺序可以改变。你不需要考虑数组中超…...

【每日一题】—— C. Challenging Cliffs(Codeforces Round 726 (Div. 2))
🌏博客主页:PH_modest的博客主页 🚩当前专栏:每日一题 💌其他专栏: 🔴 每日反刍 🟡 C跬步积累 🟢 C语言跬步积累 🌈座右铭:广积粮,缓称…...
想在金融界拥有一席之地吗—社科院杜兰大学金融管理硕士助你圆梦
追求高学历是为了什么?一纸证书吗?显然并非如此,只有读过研的人才有话语权。在上升一个平台后,你必然会发现,更高学历得到的不止是一张文凭。而是更大的平台、更广阔的视野、更包容的环境,更多样的文化。最…...
Moonbeam与Nodle网络集成,增添物联网功能
领先的波卡跨链互连开发平台Moonbeam近期宣布与Nodle Network达成XCM集成,将NODL Token带到Moonbeam生态之中。本次集成将会开启波卡中Moonbeam和Nodle网络以及通过Moonbeam互连合约相连的远程链之间的流动性。 Nodle网络是一个为物联网(Internet of Th…...
关于docker 在ubuntu16.04 上的安装
https://www.sohu.com/a/708313241_121368355 参考教程: https://www.runoob.com/docker/docker-image-usage.html 镜像网址 https://hub.docker.com/...
Cmder启动加速
Cmder是一个比较好用的命令行工具,可以通过修改默认Git地址提高启动速度: 打开vendor/init.bat添加本机Git地址,并且打开启动时间显示 :: Use /v command line arg or set to > 0 for verbose output to aid in debugging. set GIT_INSTA…...

【windows】windows上如何使用linux命令?
前言 windows上的bat命令感觉不方便,想在windows上使用linux命令。 有人提供了轮子,本文简单介绍一些该轮子的安装与使用,希望能够帮助到和我有一起需求的网友。 我的答案是busybox。 1.安装busybox.exe 在这个网站上安装busybox busyb…...
Docker Compose: 集合管理Docker的工具安装
Docker Compose:集合管理多个Docker容器的工具,在安装docker时windows,macos默认安装Docker Compose,linux需要自己手动安装 去官网https://github.com/docker/compose/releases下载需要的版本$ sudo chmod x ./docker-compose-linux-x86_64$ sudo cp .…...

Jmeter(三) - 从入门到精通 - 测试计划(Test Plan)的元件(详解教程)
1.简介 上一篇中已经教你如何通过JMeter来创建一个测试计划(Test Plan),那么这一篇我们就将JMeter启动起来,创建一个测试计划(Test plan),然后给大家介绍一下测试计划(Test Plan&am…...

20天学会rust(一)和rust say hi
关注我,学习Rust不迷路 工欲善其事,必先利其器。第一节我们先来配置rust需要的环境和安装趁手的工具,然后写一个简单的小程序。 安装 Rust环境 Rust 官方有提供一个叫做 rustup 的工具,专门用于 rust 版本的管理,网…...

嵌入式传感器将是未来智能交通发展的关键
随着移动即服务(MaaS)被视为智能移动的关键要素,对增长至关重要的一大因素是机器人车辆技术,而机器人技术又将高度依赖嵌入式传感器。 在这种情况下,高端传感器技术和原始计算能力将成为持续不断的市场扰乱的核心&…...

Vue3 实现产品图片放大器
Vue3 实现类似淘宝、京东产品详情图片放大器功能 环境:vue3tsvite 1.创建picShow.vue组件 <script lang"ts" setup> import {ref, computed} from vue import {useMouseInElement} from vueuse/core/*获取父组件的传值*/ defineProps<{images:…...

机器学习笔记 - 使用 YOLOv5、OpenCV、Python 和 C++ 检测物体
一、YOLO v5简述 YOLO v5虽然已经不是最先进的对象检测器,但是YOLOv5 使用了一个简单的卷积神经网络 CNN架构(相对YOLO v8来讲,不过v8精度是更高了一些),更易理解。这里主要介绍如何轻松使用 YOLO v5来识别图像中的对象。将使用 OpenCV、Python 和 C++ 来加载和调用我们的…...

使用手机相机检测电脑屏幕刷新率Hz
使用手机相机检测电脑屏幕刷新率Hz 1、电脑打开https://www.testufo.com/frameskipping 2、相机专业模式:快门1/10、ISO自动,拍摄一张照片。120Hz至少要有12个亮块,50Hz至少有6个亮块。 更改刷新速率 1、选择 “开始>设置>系统>显示…...

修改k8s pod的挂载目录
1、找到挂载的服务 kubectl get service2、编辑pod的环境配置 kubectl edit deployment vendor-basic-bill-executor3、找到需要挂载的目录...

Vue3+SpringBoot快速开发模板
起因:个人开发过程经常会使用到Vue3SpringBoot技术栈来开发项目,每次在项目初始化时都需要涉及一些重复的整理工作,于是结合一些个人觉得不错的前后端模板进行整合,打通一些大多数项目都需要的实现的基础功能,以便于快…...
CSDN竞赛68期
CSDN竞赛68期 CSDN竞赛68期1.小球游戏2.王子闯闸门分析 CSDN竞赛68期 1.小球游戏 这个是64期的题目,完全一样,有点无语了,竟然又出了,真不知道怎么出的题。 参考:CSDN周赛64期 2.王子闯闸门 波斯王子要去救被贾法尔…...

Redis入门
目录 一、Redis简介 二、主要特点 三 、Redis的下载与安装 1.2.1 Redis下载 1.2.2 Redis安装 1.3 Redis服务启动与停止 1.3.1 服务启动命令 1.3.2 客户端连接命令 1.3.3 修改Redis配置文件 1.3.4 Redis客户端图形工具 一、Redis简介 Redis是一个基于内存的key-value…...

[CrackMe]BuLLeT.exe的逆向及注册机编写
Delphi写的, 其实这个crackme很弱鸡, 但我还是花了好几个小时逆向, 一来是因为我第一次逆向delphi程序, 二来里面有很多转换函数, 我以为是加密函数, 结果一个个分析花了很多时间。但感觉学到了不少。 查壳发现加了一个WWPACK壳(没见过这种壳)。 进去之后不是在ntdll.dll里面,…...

Chapter03-Authentication vulnerabilities
文章目录 1. 身份验证简介1.1 What is authentication1.2 difference between authentication and authorization1.3 身份验证机制失效的原因1.4 身份验证机制失效的影响 2. 基于登录功能的漏洞2.1 密码爆破2.2 用户名枚举2.3 有缺陷的暴力破解防护2.3.1 如果用户登录尝试失败次…...

C++初阶-list的底层
目录 1.std::list实现的所有代码 2.list的简单介绍 2.1实现list的类 2.2_list_iterator的实现 2.2.1_list_iterator实现的原因和好处 2.2.2_list_iterator实现 2.3_list_node的实现 2.3.1. 避免递归的模板依赖 2.3.2. 内存布局一致性 2.3.3. 类型安全的替代方案 2.3.…...
系统设计 --- MongoDB亿级数据查询优化策略
系统设计 --- MongoDB亿级数据查询分表策略 背景Solution --- 分表 背景 使用audit log实现Audi Trail功能 Audit Trail范围: 六个月数据量: 每秒5-7条audi log,共计7千万 – 1亿条数据需要实现全文检索按照时间倒序因为license问题,不能使用ELK只能使用…...

dedecms 织梦自定义表单留言增加ajax验证码功能
增加ajax功能模块,用户不点击提交按钮,只要输入框失去焦点,就会提前提示验证码是否正确。 一,模板上增加验证码 <input name"vdcode"id"vdcode" placeholder"请输入验证码" type"text&quo…...

转转集团旗下首家二手多品类循环仓店“超级转转”开业
6月9日,国内领先的循环经济企业转转集团旗下首家二手多品类循环仓店“超级转转”正式开业。 转转集团创始人兼CEO黄炜、转转循环时尚发起人朱珠、转转集团COO兼红布林CEO胡伟琨、王府井集团副总裁祝捷等出席了开业剪彩仪式。 据「TMT星球」了解,“超级…...

Springcloud:Eureka 高可用集群搭建实战(服务注册与发现的底层原理与避坑指南)
引言:为什么 Eureka 依然是存量系统的核心? 尽管 Nacos 等新注册中心崛起,但金融、电力等保守行业仍有大量系统运行在 Eureka 上。理解其高可用设计与自我保护机制,是保障分布式系统稳定的必修课。本文将手把手带你搭建生产级 Eur…...

PL0语法,分析器实现!
简介 PL/0 是一种简单的编程语言,通常用于教学编译原理。它的语法结构清晰,功能包括常量定义、变量声明、过程(子程序)定义以及基本的控制结构(如条件语句和循环语句)。 PL/0 语法规范 PL/0 是一种教学用的小型编程语言,由 Niklaus Wirth 设计,用于展示编译原理的核…...

QT: `long long` 类型转换为 `QString` 2025.6.5
在 Qt 中,将 long long 类型转换为 QString 可以通过以下两种常用方法实现: 方法 1:使用 QString::number() 直接调用 QString 的静态方法 number(),将数值转换为字符串: long long value 1234567890123456789LL; …...

华为云Flexus+DeepSeek征文|DeepSeek-V3/R1 商用服务开通全流程与本地部署搭建
华为云FlexusDeepSeek征文|DeepSeek-V3/R1 商用服务开通全流程与本地部署搭建 前言 如今大模型其性能出色,华为云 ModelArts Studio_MaaS大模型即服务平台华为云内置了大模型,能助力我们轻松驾驭 DeepSeek-V3/R1,本文中将分享如何…...
CppCon 2015 学习:Time Programming Fundamentals
Civil Time 公历时间 特点: 共 6 个字段: Year(年)Month(月)Day(日)Hour(小时)Minute(分钟)Second(秒) 表示…...