[MySQL]数据类型

数据类型

1.数据类型分类

接下来就对上面的四种类型进行介绍

2.数值类型

数值类型就和我们c语言中的整形类型一样,tinyint就是char类型,smallint就是short类型,这里我们拿tinyint类型来举例

2.1 tinyint类型

当我们创建的时候没有写是无符号还是有符号类型,系统默认的就是有符号类型。

可以看到tinyint类型最大就是127了,超过上限之后mysql不允许我们插入数值(这就是一种约束后面会提到)。

无符号类型举例

这里无符号类型就不允许我们插入负数。

3.bit类型

3.1 基本语法

c 复制代码
bit[(M)] : 位字段类型。M表示每个值的位数,范围从1到64。如果M被忽略,默认为1。

bit类型是要自己去定这个类型的位数的。

这里很奇怪,bit里面我们填入了10,但是并没有给我们显示出来, 这是因为bit字段在显示时,是按照ASCII码对应的值显示

所以bit的一般用法就是定义bit的大小为1,只存放0和1的值,这样更节省我们的空间。

4. 小数类型

4.1 float语法

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

举例:

小数:float(4,2)表示的范围是-99.99 ~ 99.99

另外,我们存入100.0,看似是长度是4,但是系统会在插入时判断这个数字为100.00,所以还是不可以插入的。

cpp 复制代码
float是会四舍五入的。
如果float是无符号的,
例如float(4,2),那表示的范围就是0~99.99,并不会扩大范围!

4.2 decimal语法

decimal(m, d) [unsigned] : 定点数m指定长度,d表示小数点的位数

decimal(5,2) 表示的范围是 -999.99 ~ 999.99

decimal(5,2) unsigned 表示的范围 0 ~ 999.99

cpp 复制代码
float在存入数据的时候会出现精度损失的问题,所以引入decimal。

可以看出在存储精确度很高小数的时候用decimal更有优势。

float表示的精度大约是7位。

decimal整数最大位数m为65。支持小数最大位数d是30。如果d被省略,默认为0.如果m被省略,默认是10。

5.字符串类型

5.1 char类型

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

可以看到在mysql中,一个汉字就代表了一个字符,和字母是一样的。

5.2 varchar

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

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

1.varchar长度可以指定为0到65535之间的值,但是有1 - 3 个字节用于记录数据大小,所以说有效字节数是65532

2.当我们的表的编码是utf8时,varchar(n)的参数n最大值是65532/3=21844[因为utf中,一个字符占用3个字节],如果编码是gbk,varchar(n)的参数n最大是65532/2=32766(因为gbk中,一个字符占用2字节)。

这里要重点一下:变长的意义就是定上限,没有达到上限之前,那么这里的值就是存的数据的大小,但是存入的数据不能超过我们输入的值。

6.日期类型

可以看到这里我们没有插入t3的值,但是它却有值,所以timestamp就是一种时间戳当我们插入数据的时候时间戳就会自动补齐。我们再来实验一下

更新数据的时候t3也会自动更新。

7.enum和set

说了那么多,其实就是enum就是单选,set就是多选

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

查询语句

cpp 复制代码
 select * from votes where hobby='登山';

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

相关推荐
小O的算法实验室几秒前
2026年IEEE TASE,面对突发危险区域的基于强化学习的多无人机路径规划,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
咬_咬1 分钟前
go语言学习(数组与切片)
开发语言·学习·golang·数组·切片
小陈工3 分钟前
Python Web开发入门(十八):跨域问题解决方案——从“为什么我的请求被拦了“到“我让浏览器乖乖听话“
开发语言·python·机器学习·架构·数据挖掘·回归·状态模式
m0_497214154 分钟前
Qt事件系统
开发语言·qt
AI科技星4 分钟前
全维度相对论推导、光速螺旋时空与北斗 GEO 钟差的统一理论
开发语言·线性代数·算法·机器学习·数学建模
ECT-OS-JiuHuaShan8 分钟前
科学的本来意义,是基于规范的共识逻辑,而非共识方法
人工智能·科技·学习·算法·生活
赵优秀一一9 分钟前
Python 工程化基础1:环境(conda)、pip、requirements.txt
linux·开发语言·python
木子墨51614 分钟前
LeetCode 热题 100 精讲 | 动态规划进阶篇:最大子数组和 · 分割等和子集 · 最长公共子序列 · 打家劫舍 III
数据结构·c++·算法·leetcode·动态规划·力扣
刘~浪地球15 分钟前
数据库与缓存--MySQL 高可用架构设计
数据库·mysql·缓存
知识分享小能手18 分钟前
MongoDB入门学习教程,从入门到精通,MongoDB的了解应用程序的动态(18)
数据库·学习·mongodb