Mysql 数据结构

MySQL 数据类型

整数类型

类型使用的字节数越多,意味着能表示的数值范围就越大,但是也就越耗费存储空间。MySQL 整数类型如下:

类型字节数无符号取值范围有符号取值范围含义
tinyint10~2^8-1-27~27-1非常小的整数
smallint20~2^16-1-216~216-1小的整数
mediumint30~2^24-1-224~224-1中等大小的整数
int40~2^32-1-232~232-1标准的整数
bigint80~2^64-1-264~264-1大整数

浮点数类型

首先我们要知道小数再二进制中的表现形式,例如小数5.6,整数部分5用2进制为101,小数部分0.6,进制转换公式如下:

小数部分×2设定为基数,如果基数小于1,当前位置就为0,余数=基数;基数大于1,当前位置为1,基数=基数-1

0.6*2=1.2>1,当前数为1,基数=1.2-1=0.2

0.2*2=0.4<1,当前数为0,基数=0.4

0.4*2=0.8<1,当前数为0,基数=0.8

0.8*2=1.6>1,当前数为1,基数=1.6-1=0.6

0.6*2=1.2>1,当前数为1,基数=1.2-1=0.2

所以5.6的二进制表示为101.10011,或1.0110011*2^2。 我们把小数点之后的0110011成为尾数,把2^2上的指数值称为指数,然后只需要在计算机中的二进制位中表示出尾数和指数就行了

很显然,使用的字节数越多,表示尾数和指数的范围就越大,也就是说表示的小数范围就越大,所以设计MySQL根据表示一个小数需要的不同字节数定义了如下的两种类型来表示小数:

类型字节数绝对值最小非0值绝对值最大非0值含义
float4±1.175…e^-38±3.402…e^38单精度浮点数
double8±2.225…e^-308±1.797…e^308双精度浮点数

需要注意的是,很多小数是无法转成二进制的,它们转成二进制数也为一个无限小数,如0.3,但是我们只能用4个字节或者8个字节来表示这个小数,因此计算机的浮点数是不精确的。

还有个概念是有效位数和小数位数

FLOAT(M,D)或DOUBLE(M,D),M指的是‘有效位数’,D指的是‘小数位数’。在小数位数相同的情况下,有效位数越多,该类型的取值范围越大;在有效位数相同的情况下,小数位数越大,该类型的取值范围越小

定点数类型

因为浮点数表示小数有不精确的情况,所以设计出了定点数用来精确计数:decimal。DECIMAL(M,D),M 指的是有效位数,D指的是小数位数。

如DECIMAL(5,2),其取值范围为 -999.99-999.99。M的范围是1-65,D的范围是0~30,MySQL 中 D的值不能超过M。小数多出位数时会进行四舍五入。

字符串类型

同一个字符,对于不同的字符编码使用的字节数是不同的,由此分为下边两种:

  • 固定长度编码

    采用相同的字节数来表示一个字符,比方说ASCII编码方式采用1个字节来表示一个字符,ucs2采用2个字节来表示一个字符。

  • 变长编码

    采用长度不一样的字节来表示不同的字符,比方说utf8编码方式采用13个字节来编码一个字符,gb2312采用12个字节来编码一个字符。

CHAR

char(M)中 M(字符数量) 的取值范围是0~255,它占用的存储空间是固定的。当你设定 CHAR(M)时,它会根据编码占用相应的字节数。

如果 CHAR(M) 占用的存储空间大于实际字符串需要的存储空间,那多出的存储空间将被空格填满,所以char类型存储的字符串末尾不能有空格。这种CHAR(M)的字符串类型有一个非常不好的地方:一旦你确定了M的值,如果M的值很大,而你实际存储的字符串占用字节数又很少,会造成存储空间的浪费。

VARCHAR

VARCHAR 为了存储长短不一字符串而生。VARCHAR(M) 中的 M 是指定你要存储的字符串最多包含的个数,其取值范围是1~65535。但是 MySQL中数据大小是有限制的,大小为64k,即65535个字节,并且 MySQL 中 UTF-8 编码格式下一个字符占用3个字节,因此你懂的。

VARCHAR 类型数据占用的存储空间由两部分组成:

  1. 真正的字符串内容
  2. 占用字节数

假设真正的字符串内容编码后占用字节数为 L,因为某一行包含的所有列中存储的数据大小不得超过65535个字节,所以L不可能大于65535,所以我们最多用两个字节来表示真正数据占用的字节长度就可以了,也就是说VARCHAR(M)实际占用的存储空间只可能是L+1个字节或者L+2个字节

其他的 text 类型是不限定数据大小的,在下表列出:

类型最大长度
tinytext2^8-1个字节
text2^16-1个字节
mediumtext2^24-1个字节
longtext2^32-1个字节

ENUM 和 SET

ENUM,枚举类型,在给定字符串列表中选择一个。

SET,在给定字符串列表中选择多个

日期时间类型

MySQL 提供了如下几种日期时间类型:

类型字节数日期格式范围
DATATIME8YYYY-MM-DD HH:MM:SS1000-01-01 00:00:00 ~ 9999-12-31 23:59:59
TIMESTAMP4YYYY-MM-DD HH:MM:SS1970-01-01 08:00:01 ~ 2038 年的某个时刻
DATE4YYYY-MM-DD1000-01-01 ~ 9999-12-31
TIME3HH:MM:SS-838:59:59 ~ 838:59:59
YEAR1YYYY1901 ~ 2155

上表简单明了,可以根据自己的需要选择合适的类型来节约储存空间,但也需要注意几点:

  1. DATETIME 由 DATE 和 TIME 组成,表示一天内的时间,而 TIME 表示的是一段时间,是有正负值的
  2. TIMESTAMP 的范围比 DATETIME 小,它展示的值是随着时区的变化而变化

二进制类型

我主要说一下 BLOB 类型

BLOB类型是一种特殊的二进制类型。BLOB 可以用来保存数据量很大的二进制数据,如图片等。BLOB 类型包括TINYBLOB、BLOB、MEDIUMBLOB 和 LONGBLOB。这几种 BLOB 类型最大的区别就是能够保存的最大长度不同。

类型字节数
TINYBLOB2^8-1
BLOB2^16-1
MEDIUMBLOB2^24-1
LONGBLOB2^32-1
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值