mysql5.7四字节中文_mysql 字节问题,中文和数字

本文介绍了MySQL中不同字符集如latin1、utf8、gbk的特点,以及它们对存储汉字和字母的影响。此外,还详细阐述了各种数字类型如TINYINT、INT、BIGINT的字节数及表示范围,以及日期时间类型如DATE、DATETIME的存储空间。最后,文章提及了字符串类型如CHAR、VARCHAR、BLOB等的存储机制。
摘要由CSDN通过智能技术生成

在mysql 5.1.5-alpha下测试得出如下结论

latin1:

1character=1byte, 1汉字=2character,

也就是说一个字段定义成 varchar(200),则它可以存储100个汉字或者200个字母。

这一点要注意,尤其是当字段内容是字母和汉字组成时,尽量假设字段内容都是由汉字组成,据此来设置字段长度

utf8:

1character=3bytes, 1汉字=1character

也就是说一个字段定义成 varchar(200),则它可以存储200个汉字或者200个字母。

gbk:

1character=2bytes,1汉字=1character

也就是说一个字段定义成 varchar(200),则它可以存储200个汉字或者200个字母。

数字类型

根据字节数即可算出表示的范围了

TINYINT                                    1 字节

SMALLINT                                 2 个字节

MEDIUMINT                              3 个字节

INT                                           4 个字节

INTEGER                                   4 个字节

BIGINT                                      8 个字节

FLOAT(X)                                  4 如果 X < = 24 或 8 如果 25 < = X < = 53

FLOAT                                       4 个字节

DOUBLE                                    8 个字节

DOUBLE PRECISION                  8 个字节

REAL                                         8 个字节

DECIMAL(M,D)                          M字节(D+2 , 如果M < D)

NUMERIC(M,D)                          M字节(D+2 , 如果M < D)

日期和时间类型

DATE                                        3 个字节

DATETIME                                 8 个字节

TIMESTAMP                               4 个字节

TIME                                         3 个字节

YEAR                                         1 字节

字符串类型

CHAR(M)                                        M字节,1 <= M <= 255

VARCHAR(M)                                 L+1 字节, 在此L <= M和1 <= M <= 255

TINYBLOB, TINYTEXT                     L+1 字节, 在此L< 2 ^ 8

BLOB, TEXT                                   L+2 字节, 在此L< 2 ^ 16

MEDIUMBLOB, MEDIUMTEXT         L+3 字节, 在此L< 2 ^ 24

LONGBLOB, LONGTEXT                 L+4 字节, 在此L< 2 ^ 32

ENUM(‘value1‘,‘value2‘,...)                1 或 2 个字节, 取决于枚举值的数目(最大值65535)

SET(‘value1‘,‘value2‘,...)                    1,2,3,4或8个字节, 取决于集合成员的数量(最多64个成员)

其中:

1. bit:位

一个二进制数据0或1,是1bit;

2. byte:字节

存储空间的基本计量单位,如:MySQL中定义 VARCHAR(45)  即是指 45个字节;

1 byte = 8 bit

3. 一个英文字符占一个字节;

1 字母 = 1 byte = 8 bit

4. 一个汉字占2个字节;

1 汉字 = 2 byte = 16 bit

byte:一个字节(8位)(-128~127)(-2的7次方到2的7次方-1)

short:两个字节(16位)(-32768~32767)(-2的15次方到2的15次方-1)

int:四个字节(32位)(一个字长)(-2147483648~2147483647)(-2的31次方到2的31次方-1)

long:八个字节(64位)(-9223372036854774808~9223372036854774807)(-2的63次方到2的63次方-1)

float:四个字节(32位)(3.402823e+38 ~ 1.401298e-45)(e+38是乘以10的38次方,e-45是乘以10的负45次方)

double:八个字节(64位)(1.797693e+308~ 4.9000000e-324

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值