MySQL:表中的数据类型

数值类型

int类型

int类型包含以下五种:

类型 大小
tinyint 1 byte
smallint 2 byte
mediumint 3 byte
int 4 byte
bigint 8 byte

t1num列的类型就是tinyint,我们尝试对其插入数据,来测试其范围。tinynt1 byte,那么就可以表示256个数字。

成功插入了-1,说明tinyint默认是有符号的。其实整个int家族,默认都是带符号的

如果想要不带符号,建表时在类型的末尾后紧跟unsigned

tinyint有符号时,存储范围是[-128, 127];无符号时,范围是[0, 255]。其它int家族的成员同理。


bit类型

顾名思义,bit类型就是自己指定比特位的数目。

语法:

bit(M)

其中M表示比特位的数目,如果省略(M)则默认表示一个比特位,M的取值范围是[1, 64]

t3表有两列,分别是idonlineonline的类型是bit(1)(也可省略为bit),即只占用一个比特位。

分别对online插入0, 1, 2,发现01可以正常插入,但是2不行,因为一个比特只能表示01bit类型在输出时,默认以ASCII码的形式展示 ,而01ASCII码中是控制字符,不可输出,所以我们看不到。

我现在将bit(1)改为bit(10),然后插入数字97

可以看到,最后数字97输出时,输出的是97对应的字符'a'


浮点类型
float / double

floatdouble用于存储浮点型,也就是小数,占用内存如下:

类型 大小
float 4 byte
double 8 byte

语法:

float(m, d) [unsigned]

其中m指定浮点数的总长度,d指定小数位数。

float(4, 2),表示整个浮点数占4位数字,小数点后占2位,也说明了小数点前的数字位数是4 - 2 = 2位,存储范围是[-99.99, 99.99]

如果希望存储无符号的数字,那么就是float(4, 2) unsigned,但是与整数不同,unsigned对浮点数只影响最小值为0,最大值不变,此时存储范围变成[0, 99.99].

首先创建一张表,其中第二列num的类型是float(4,2)

99.99正常插入了,但是100超出范围了,可见99.99是边界值。

可知:当小数点后位数不足时,自动补0到精度。

可知:当小数点后超出精度,此时发生四舍五入

float可以不指定(m, d),此时直接使用 float 不会强制保留固定数量的小数位,而是更具输入的数字实时调整。

  1. 直接使用float,数字的位数可以根据插入的值自由调整
  2. 对于精度较高的数字,无法很好的保存,会四舍五入

一般来说,float的精度是7位十进制数字,包括小数点前后。而456.789108位数字,所以发生了精度损失。

在插入较大的整数时,整数也会有损失,比如插入123456789


decimal

从刚刚的float讲解可以看出:float与double会有精度损失,不适合存储对精度要求高的小数,因此MySQL推出了decimal类型,专门用于存储高精度要求的浮点数

语法:

decimal(m,d) [unsigned]

decimal最大的m65,最大的d30。如果省略m,则默认m=0,如果省略d,则默认d=10

在使用上,decimalfloat / double没有任何区别。


字符串类型

MySQL中,字符串使用了charvarchar来存储,与大部分编程语言不同,编程语言中char往往只存储一个字符。

char

char用于存储固定长度的字符串。

语法:

char(L)

L用于指定字符串的最大长度L的最大值为255

字符串'a''ab''abc'都插入成功了,而'abcd'超出了长度,插入失败。

字符串'中国人'插入成功了,根据utf8编码规则,普通字母占1 byte,而汉字占3 byte。在部分编程语言中,例如C/C++,汉字算作三个字符,但是MySQL中认为一个汉字也是一个字符


varchar

语法:

varchar(L)

L用于指定字符串的最大长度,L的最大值为不确定,但是最大字节数为65535

对于char来说,如果指定了字符串的长度,那么存入的所有字符串都是这个长度所占字节的大小。对于varchar来说,只要存入的字符串没有超过指定长度,那么该字符串占用多少内存,就实际开辟多少内存!

经过计算,若以utf8编码,varchar最大能存储65535 / 3 = 21845个字符。

BUT,因为varchar类型每个字符串占用的字节数不确定,所以读取内存时,不知道这个字符串读取到啥时候结束,所以在整个字符串的首部,需要开辟1 - 3 byte,来存储这个字符串的长度 。总共有65535 byte,减去首部占用的3 byte,最后能用的只有(65535 - 3) / 3 = 21844个字符.


日期时间类型

MySQL中,日期与时间也有专门的类型来存储,包以下三种:

类型 含义 格式 大小
data 日期 yyyy-mm-dd 4 byte
datetime 日期 + 时间 yyyy-mm-dd HH:ii:ss 8 byte
timestamp 时间戳 yyyy-mm-dd HH:ii:ss 4 byte

通过desc可以看到,timestamp的默认值DefaultCURRENT_TIMESTAMP,也就是当前的时间

time1time2都按照正常格式插入了,与之同时time3自动更新为了当前时间。一般来说timestampdatetime没有格式上的区别,但是由于timestamp会自动更新,所以一般用于保存最后一次的修改时间.


enum & set

enum为枚举类型,用于进行单选。

语法:

enum('选项1', '选项2', '选项3', ...)

set为集合类型,用于进行多选。

语法:

set('选项1', '选项2', '选项3', ...)

现在创建了表t10,其第二列gender为枚举enum,第三列hobby为集合set。通过desc可知,enumset都允许为NULL

张三有多个爱好,此时多个选项用逗号隔开:'篮球,羽毛球'

那么对于enum和set来说,它们底层都使用数字来存储。

  • enum中,选项从前往后分别用数字1,2,3,4,5...表示,最大值为65535
  • set中,选项通过位图存储,第一个选项为二进制1,第二个选项为二进制10,第三个选项为二进制100,以此类推,最多64个选项

比如enum('男','女','保密')中,'男' = 1,'女' = 2,'保密' = 3;set('羽毛球','乒乓球','篮球','足球') 中,'羽毛球' = 1,'乒乓球' = 2,'篮球' = 4,'足球' = 8。

在插入时,如果想选中'羽毛球,足球',就可以插入8+1=9.

对于set,多选包括不选,插入空字符串'',或者数字0都可: 此处要注意,空串表示啥也不选,此处表示这个人没有任何爱好。而NULL表示缺少这个值,此处表示这个人的爱好不确定

相关推荐
云和数据.ChenGuang44 分钟前
Django 应用安装脚本 – 如何将应用添加到 INSTALLED_APPS 设置中 原创
数据库·django·sqlite
woshilys1 小时前
sql server 查询对象的修改时间
运维·数据库·sqlserver
Hacker_LaoYi1 小时前
SQL注入的那些面试题总结
数据库·sql
建投数据2 小时前
建投数据与腾讯云数据库TDSQL完成产品兼容性互认证
数据库·腾讯云
Hacker_LaoYi3 小时前
【渗透技术总结】SQL手工注入总结
数据库·sql
岁月变迁呀3 小时前
Redis梳理
数据库·redis·缓存
独行soc3 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍06-基于子查询的SQL注入(Subquery-Based SQL Injection)
数据库·sql·安全·web安全·漏洞挖掘·hw
你的微笑,乱了夏天4 小时前
linux centos 7 安装 mongodb7
数据库·mongodb
工业甲酰苯胺4 小时前
分布式系统架构:服务容错
数据库·架构
独行soc5 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍08-基于时间延迟的SQL注入(Time-Based SQL Injection)
数据库·sql·安全·渗透测试·漏洞挖掘