zoukankan      html  css  js  c++  java
  • mysql 数据类型day43

    数据类型
    一数值类型
    1 整数类型 默认是有符号的
    unsigned 没有符号 zerofill0t
    小整数 TINYINT [(m)] 1个字节 8bit 2**8 256
    m 最多3位 最低 -128 最高255 用于保存一些范围的整数数值范围
    有符号-128 - 127
    无符号(unsigned)
    0-255
    整数 INT [(m)] 4个字节 32bit 2**32 4294967295
    m 最多11位包括符号 默认只能是10位
    最低 -2147483648 最高4294967295
    有符号 -2147483648 ~ 2147483647
    无符号(unsigned)
    0-4294967295


    大整数 bigint[(m)] 8字节 2**64
    大整数,数据类型用于保存一些范围的整数数值范围:
    有符号:
    -9223372036854775808 ~ 9223372036854775807
    无符号:
    0 ~ 18446744073709551615
    有符号和无符号的最大数字需要的显示宽度均为10,而针对有符号的最小值则需要11位才能显示完全,
    所以int类型默认的显示宽度为11是非常合理的

    最后:整形类型,其实没有必要指定显示宽度,使用默认的就ok
    2 浮点型
    float(M,D) M
    定义:
       单精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30
    DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]

        定义:
    双精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30

        有符号:
    -1.7976931348623157E+308 to -2.2250738585072014E-308
    2.2250738585072014E-308 to 1.7976931348623157E+308

          无符号:
    2.2250738585072014E-308 to 1.7976931348623157E+308

        精确度:
    ****随着小数的增多,精度比float要高,但也会变得不准确 ****

      decimal[(m[,d])] [unsigned] [zerofill]

         定义:
    准确的小数值,m是数字总个数(负号不算),d是小数点后个数。 m最大值为65,d最大值为30。


        精确度:
      **** 随着小数的增多,精度始终准确 ****
    对于精确数值计算时需要用此类型
    decaimal能够存储精确值的原因在于其内部按照字符串存储。

    准确度一次增加
    二 字符串类型

    1 char类型:定长,简单粗暴,浪费空间,存取速度快 最长是10位
       字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)
       存储:
    存储char类型的值时,会往右填充空格来满足长度
    例如:指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储
    2 varchar类型:变长,精准,节省空间,存取速度慢
       字符长度范围:0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8:
    三 日期类型
    YEAR
    DATE
    TIME
    DATETIME
    TIMESTAMP
    YEAR
    YYYY(1901/2155)

    DATE
    YYYY-MM-DD(1000-01-01/9999-12-31)

    TIME
    HH:MM:SS('-838:59:59'/'838:59:59')

    DATETIME

    YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59 Y)

    TIMESTAMP

    YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)
    四 枚举类型和集合类型
    enum 单选 只能在给定的范围内选一个值,如性别 sex 男male/女female
    set 多选 在给定的范围内可以选择一个或一个以上的值(爱好1,爱好2,爱好3...)
    enum类型
    CREATE TABLE shirts (
    name VARCHAR(40),
    size ENUM('x-small', 'small', 'medium', 'large', 'x-large')
    );
    INSERT INTO shirts (name, size) VALUES ('dress shirt','large'),
    ('t-shirt','medium'),
    ('polo shirt','small');

    集合类型(set)
    A SET column can have a maximum of 64 distinct members.
    示例:
    CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));
    INSERT INTO myset (col) VALUES ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');
  • 相关阅读:
    windows server 2008 r2 切换windows 7主题方法
    JAVA环境安装
    Oracle 11gR2 安装教学
    webmin-1.810 安装
    Windows Squid 安装配置
    Zyxel Switch-How to block a fake DHCP server without enabling DHCP snooping?
    Java介绍
    cookies和session区别
    牛刀小试之Django二
    小试牛刀之Django
  • 原文地址:https://www.cnblogs.com/xiaoluoboer/p/8044918.html
Copyright © 2011-2022 走看看