【MySQL 04】数据类型
目录
1.数据类型分类
2.数值类型
2.1 tinyint 类型
2.2 bit类型
2.3 float类型
2.4decimal
3.字符串类型
3.1 char类型
3.2 varchar类型
4.日期和时间类型
6. enum和set类型
6.1.enum和set类型简介:
6.2.enum和set的一般使用方法
6.3.用数字的方式插入数据
6.4.通过enum和set进行查找
通过值直接进行查找
find_ in_ set函数
1.数据类型分类
2.数值类型
2.1 tinyint 类型
用于存储非常小的整数值。在不同的数据库系统中,
tinyint的具体实现和范围可能略有不同,但大体上它可以用来存储一个很小的整数集合。
tinyint的存储范围通常是从-128到127(对于有符号的tinyint),或者从0到255(对于无符号的tinyint)。这个范围取决于是否定义了该类型为有符号(signed)或无符号(unsigned)。数值越界测试
默认有符号类型:
进行合法范围的数据插入,是完全可以的:
一旦越界就会报错:
无符号类型:
同样的,合法就可以插入数据:
2.2 bit类型
bit类型是一种用于存储位值的数据类型。bit类型在MySQL中用于存储位数据,即只能存储0或1的值。bit类型可以定义不同长度的位序列,例如bit(1)表示单个位,而bit(8)表示一个字节的位序列。最长可以定义为bit(64)。MySQL对于bit类型的存储方式可以是紧凑型或兼容型,可以通过设置BIT数据类型的N标志来控制,默认为紧凑型。基本语法:
bit[(M)] : 位字段类型。M表示每个值的位数,范围从1到64。如果M被忽略,默认为1。bit字段显示方式:
bit(8)的存储范围是从0到255显示的是20对应的十六进制
bit字段使用场景:
最常见的用途是存储布尔值(true/false),其中0可以表示false,1可以表示true。这种方式比使用
TINYINT或CHAR(1)等类型更节省空间,特别是在有大量此类字段的表中。比如性别的标识:
2.3 float类型
float类型是一种浮点数数据类型,用于存储包含小数点的数字。float类型占用4个字节(32位)的存储空间。float类型提供大约6到7位的有效数字精度,这意味着对于某些计算结果,可能会存在精度损失。float类型的值范围是从大约-3.402823466E+38到3.402823466E+38(包括负数和正数)。这是指它可以表示的最小值和最大值之间的范围。语法:
float[(m, d)] [unsigned] : M指定显示长度,d指定小数位数,占用空间4个字节范围测试
4表示一个有四个位数,2表示小数点后位数位2。float(4,2)表示的范围是-99.99 ~ 99.9
进行合法范围的数据插入,是完全可以的:
MySQL在保存值时会进行四舍五入,因此实际合法操作范围位-99.994 ~ 99.994,后面的4会被舍弃掉
如果定义的是float(4,2) unsigned 这时,因为把它指定为无符号的数,范围是 0 ~ 99.99
2.4decimal
decimal和float很像,但是有区别:float和decimal表示的精度不一样。
FLOAT类型在MySQL中是一个近似数值数据类型,它可能不会存储完全精确的数值。这是因为FLOAT类型使用IEEE 754标准来表示浮点数,这可能会导致舍入误差。
DECIMAL类型提供精确的小数表示,这意味着它可以存储的数值具有完全的可预测性和准确性,不会有FLOAT和DOUBLE类型那样的舍入误差。语法:
decimal(m, d) [unsigned] : 定点数m指定长度,d表示小数点的位数两者精度的对比:
下面表,字段num1 float(10,8),字段num2 decimal(10,8)。然后插入数据23.12345612
,我们可以很明显的看到,float对应字段很明显发生了精度的误差。
3.字符串类型
在不同的编码下,字符所占的字节数都是不固定的:UTF-8 编码的字符可能占用1到4个字节,而 GBK 编码的字符大多数情况下占用2个字节,但也可能占用更多或更少的字节。
在MySQL中以字符为单位,其中字符表示字符的个数,'a'表示为一个字符,'中国'表示为两个字符
3.1 char类型
语法:
char(L): 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255测试
t7 中 a字段类型为 char(2),最多只能存两个字符,超过字符数就会插入失败
3.2 varchar类型
varchar一开始是不开辟空间的,当有数据插入的时候,再自动开辟空间。
语法
varchar(L): 可变长度字符串,L表示字符长度关于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字节)。
char与varchar的对比
如何选择定长或变长字符串?
- 如果数据确定长度都一样,就使用定长(char),比如:身份证,手机号,md5
- 如果数据长度有变化,就使用变长(varchar), 比如:名字,地址,但是你要保证最长的能存的进去。
- 定长的磁盘空间比较浪费,但是效率高。
- 变长的磁盘空间比较节省,但是效率低。
- 定长的意义是,直接开辟好对应的空间
- 变长的意义是,在不超过自定义范围的情况下,用多少,开辟多少。
4.日期和时间类型
常用的日期有如下三个:
- date :日期 'yyyy-mm-dd' ,占用三字节
- datetime 时间日期格式 'yyyy-mm-dd HH:ii:ss' 表示范围从 1000 到 9999 ,占用八字节
- timestamp :时间戳,从1970年开始的 yyyy-mm-dd HH:ii:ss 格式和 datetime 完全一致,占用四字节
测试
类型的字段设置
DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP属性时,指定该字段在记录被创建时自动设置为当前的时间戳,并且在记录被更新时自动更新为新的当前时间戳。
此时我们进行时间的插入,那么时间戳类型的字段会自动补齐当前时间。
6. enum和set类型
6.1.enum和set类型简介:
enum:枚举,“单选”类型。该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,3,....最多65535个;当我们添加枚举值时,也可以添加对应的数字编号
enum('选项1','选项2','选项3',...)set:集合,“多选”类型该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,....最多64个。
6.2.enum和set的一般使用方法
有一个调查表votes,需要调查人的喜好, 比如(登山,游泳,篮球,武术)中去选择(可以多选),(男,女)[单选]
爱好字段对应set类型,可以多选;而性别字段对应enum类型,只能单选:
6.3.用数字的方式插入数据
enum 中提供的选项值依次对应数字1、2、3、… n 最多 65535 个
set是通过位图来表示的,每一个位就表示一个选项:
如果全选,那么位图对应的就是1111,十进制就是15
6.4.通过enum和set进行查找
通过值直接进行查找
find_ in_ set函数
它用于在一个由逗号分隔的字符串列表中查找一个字符串的位置(基于 1 的索引)。如果找到了该字符串,则返回该字符串在列表中的位置;如果没有找到,则返回 0。
使用案例:
有喜欢足球的就筛选出来
有喜欢登山和游泳的筛选出来
相关文章:
【MySQL 04】数据类型
目录 1.数据类型分类 2.数值类型 2.1 tinyint 类型 2.2 bit类型 2.3 float类型 2.4decimal 3.字符串类型 3.1 char类型 3.2 varchar类型 4.日期和时间类型 6. enum和set类型 6.1.enum和set类型简介: 6.2.enum和set的一般使用方法 6.3.用数字的方式…...
夹耳式蓝牙耳机哪个牌子最好,教你如何不踩雷
近年来,夹耳式耳机备受众人喜爱。主要原因在于其不入耳的特性,既能保护听力健康,又能让人享受到极致的音乐体验。久而久之,人们对入耳式耳机反而感到不习惯了。然而,一些想要入手夹耳式耳机的小伙伴却犯了难࿰…...
亿发零售云解析:新零售破局与年轻群体消费趋势变化
近年来,随着数字化、智能化的快速发展,“新零售”概念逐渐成为商业领域的热门话题。相比传统零售,新零售通过线上与线下的深度融合,利用大数据、人工智能等技术,赋能消费者与品牌之间的互动。尤其在年轻消费群体中&…...
zabbix“专家坐诊”第257期问答
问题一 Q:zabbix5.0监控项里的键值,怎么设置变量值?{#ABC} {$ABC} 都识别不到变量。 A:可以参考一下这个。 问题二 Q:我想问一下用odbc创建监控项,生成了json格式,如何创建一个触发器去判断里面…...
【代码笔记】
1级 第一课——cout /* C01.L01.程序的基本结构、cout语句 杨彦彬 2024.9.23日作业 (2024.9.23做) */ //调用头文件 #include<bits/stdc.h> //使用标准名字空间 using namespace std; //代码主体 int main(){//输出数字cout<<25;cout<&…...
CentOS上使用Mosquitto实现Mqtt主题消息发布和订阅mqtt主题消息连同时间戳记录到文件
场景 CentOS上使用rpm离线安装Mosquitto(Linux上Mqtt协议调试工具)附资源下载: CentOS上使用rpm离线安装Mosquitto(Linux上Mqtt协议调试工具)附资源下载-CSDN博客 上面介绍了mosquitto的离线安装。 如果业务场景中需要订阅某mqtt主题的消息并将收到消息的时间以…...
COMTRADE 录波文件 | 可视化工具 | 电能质量查看软件
COMTRADE 录波文件 | 可视化工具 | 电能质量查看软件 主要功能介绍 支持 IEEE Std C37.111-1991/1999/2013 规范。读取 ASCII 或二进制 COMTRADE 文件。查看来自 COMTRADE 配置文件的模拟和数字通道列表。将图表导出为 SVG、BMP、JPEG 和 PNG 图形格式。将显示的观察结果以 C…...
【面试宝典】面试基础指导
目录 🍔 简历怎么写 🍔 ⾯试前针对项⽬撰写完成项⽬⽂档 🍔 ⾯试前 🍔 ⾯试中 4.1 投递简历当天没有收到⾯试邀约 4.2 讲解项⽬ 4.3 讲解知识 4.4 ⾯试中关于技术选型的演变 🍔 ⾯试后 🍔 小结 &…...
Linux·权限与工具-git与gdb
1. git工具 git是一款软件,发明它的人同时发明了Linux操作系统,也就是大名鼎鼎的Linus Torvalds 林纳斯托瓦兹。后来人们把git软件包装,产生了github、gitee等平台。 git产生的初衷就是便于进行多人协同管理,同时它还可以用来将本…...
unity 如何 团队协作避免文件冲突?
在Unity团队协作中,避免文件冲突的关键在于版本控制、场景和Prefab的管理、以及沟通。以下是具体方法: 1. 使用版本控制系统 (VCS) Unity支持多个版本控制系统,如Git和Perforce。通过版本控制,每位团队成员可以独立工作&…...
VOC2007 的ImageSets/Main目录下通常有四个文件test.txt val.txt train.txt trainval.txt
在 VOC2007 的ImageSets/Main目录下通常有四个文件: test.txt:这个文件列出了用于测试的图像文件名。这些图像将在评估模型性能等测试阶段被使用。train.txt:此文件包含用于训练的图像文件名。在模型的训练过程中,程序会读取这些图…...
JavaScript中的parseInt(), Number(),+有啥区别?
文章目录 parseInt()Number()一元加号 处理 NaN 的常见方法1. 使用 isNaN() 函数检查值2. 使用 Number.isNaN() 方法3. 提供默认值4. 使用 try...catch 结构5. 使用类型守卫 在JavaScript中,parseInt(), Number(), 和一元加号 都可以用来转换值到数字类型ÿ…...
java核心基础
文章目录 1. Java开发基础1.1 DOS常用命令:(以MAC常用命令比较)1.2 JVM、JRE、JDK之间的关系1.3 Java开发环境的搭建1.4 Java的注释,标识符、标识符的命名规范1.5 变量和常量的定义及初始化1.6 Java的运算符1.7 三大语句1.8 常用的类1.8.1 ja…...
java 字符串如何通过占位符替换字符串
在Java中,可以使用String.format()方法或者MessageFormat.format()方法来通过占位符替换字符串。 例子1:使用String.format()方法 String str "Hello, %s! Today is %s."; String result String.format(str, "Alice", "Sun…...
OpenHarmony(鸿蒙南向开发)——小型系统内核(LiteOS-A)【LMS调测】
往期知识点记录: 鸿蒙(HarmonyOS)应用层开发(北向)知识点汇总 鸿蒙(OpenHarmony)南向开发保姆级知识点汇总~ 持续更新中…… 基本概念 LMS全称为Lite Memory Sanitizer,是一种实时…...
2024.9.24 数据分析
资料 111个Python数据分析实战项目,代码已跑通,数据可下载_python数据分析项目案例-CSDN博客 【数据挖掘六大项目实战】敢说这是全B站讲的最详细最通俗易懂的数据挖掘教程!整整60集!学不会来找我!-数据挖掘、数据挖掘…...
企业急于采用人工智能,忽视了安全强化
对主要云提供商基础设施上托管的资产的安全分析显示,许多公司为了急于构建和部署 AI 应用程序而打开安全漏洞。常见的发现包括对 AI 相关服务使用默认且可能不安全的设置、部署易受攻击的 AI 软件包以及不遵循安全强化指南。 这项分析由 Orca Security 的研究人员进…...
【深海王国】初中生也能画的电路板?目录合集
Hi٩(๑ ^ o ^ ๑)۶, 各位深海王国的同志们,早上下午晚上凌晨好呀~辛勤工作的你今天也辛苦啦 (o゜▽゜)o☆ 今天大都督为大家带来系列文章《初中生也能画的电路板》,帮你一周内快速入门PCB设计,手把手教你从元器件库添加、电路原理图绘制、…...
Java日期格式化注解@DateTimeFormat和@JsonFormat
DateTimeForma 这个注解主要用于处理从前端传递到后端的日期和时间数据。当你的 Spring 应用程序接收到一个 http请求,并且请求参数包含日期和时间数据时,DateTimeFormat 可以帮助你将这些数据解析为 Java Date 或 LocalDateTime 对象。 JsonFormat 这…...
阿里巴巴中国站商品详情API返回值的国际化支持
阿里巴巴中国站(通常指的是1688.com或淘宝、天猫等平台的API,但具体到商品详情API时,由于阿里巴巴的API体系庞大且不断更新,我无法直接提供一个特定于某个版本或接口的完整代码示例。不过,我可以给你一个概念性的指导&…...
如何用韭菜盒子打造你的VSCode投资信息中心:5大实用功能深度体验
如何用韭菜盒子打造你的VSCode投资信息中心:5大实用功能深度体验 【免费下载链接】leek-fund :chart_with_upwards_trend: 韭菜盒子VSCode插件,可以看股票、基金、期货等实时数据。 LeekFund turns your VS Code and Cursor into a real-time stock, fun…...
Fluent模拟火箭发动机喷管?试试用分子动理论定义气体属性,避开数据缺失的坑
火箭发动机喷管仿真中的分子动理论实战:突破高温燃气物性数据困境 当你在Fluent中打开火箭发动机喷管的仿真项目时,面对H2/CO/H2O混合燃气在3000K温度梯度下的物性参数定义,是否曾为找不到可靠数据而抓狂?传统方法需要逐个温度点…...
软件测试中的bug管理:高效定位、跟踪与修复全流程解析
在软件测试全生命周期中,bug管理是保障产品质量、提升开发效率的核心环节。从bug的精准定位到全流程跟踪,再到最终的有效修复,每一个步骤都需要专业的方法、工具与团队协作。对于软件测试从业者而言,掌握科学的bug管理体系&#x…...
C语言数组内存布局解析:从连续存储到性能优化实践
1. 项目概述:从内存视角重新认识C语言数组很多C语言初学者,包括一些已经工作一两年的朋友,对数组的理解可能还停留在“一组连续的同类型变量”这个层面。这没错,但如果你只看到这一层,写代码时就容易踩坑,尤…...
word删除空白页
行距固定值,1磅...
告别黑盒渲染!用Nvdiffrast手把手教你从零搭建可微渲染管线(PyTorch版)
从零构建可微渲染管线:Nvdiffrast深度实践指南 在计算机图形学与深度学习交叉领域,可微渲染技术正掀起一场革命。传统渲染管线如同黑盒,输入3D场景参数,输出2D图像,但反向路径却被阻断——这正是Nvdiffrast要解决的痛点…...
御坂翻译器:3分钟开启你的日语游戏无障碍之旅
御坂翻译器:3分钟开启你的日语游戏无障碍之旅 【免费下载链接】MisakaTranslator 御坂翻译器—Galgame/文字游戏/漫画多语种实时机翻工具 项目地址: https://gitcode.com/gh_mirrors/mi/MisakaTranslator 你是否曾经因为语言障碍而错过了那些精彩的日系游戏剧…...
RVC-WebUI终极指南:5步掌握AI语音克隆与声音转换技术
RVC-WebUI终极指南:5步掌握AI语音克隆与声音转换技术 【免费下载链接】rvc-webui liujing04/Retrieval-based-Voice-Conversion-WebUI reconstruction project 项目地址: https://gitcode.com/gh_mirrors/rv/rvc-webui RVC-WebUI是一个基于检索式语音转换技术…...
【免费下载】 探索8051开发新境界:IAR for 8051(8.10版本)资源下载推荐
探索8051开发新境界:IAR for 8051(8.10版本)资源下载推荐 【下载地址】IARfor80518.10版本资源下载 IAR for 8051(8.10版本)资源下载 项目地址: https://gitcode.com/open-source-toolkit/1b6d8 项目介绍 在嵌…...
国产多模态大模型:产业协同全景与实战指南
国产多模态大模型:产业协同全景与实战指南 引言 在人工智能浪潮席卷全球的背景下,国产多模态大模型正从技术探索迈向广泛的产业协同应用。与只能处理文本或图像的单一模态模型相比,多模态大模型能同时理解、关联和生成文本、图像、音频、视频…...





























