zoukankan      html  css  js  c++  java
  • 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
  • 相关阅读:
    ZOJ2913Bus Pass(BFS+set)
    HDU1242 Rescue(BFS+优先队列)
    转(havel 算法)
    ZOJ3761(并查集+树的遍历)
    ZOJ3578(Matrix)
    HDU1505
    ZOJ3574(归并排序求逆数对)
    VUE-脚手架搭建
    VUE脚手架搭建
    VUE-node.js
  • 原文地址:https://www.cnblogs.com/aoxueshou/p/9547388.html
Copyright © 2011-2022 走看看