mysql 字节问题,中文和数字

在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