• mysql学习1:数据类型:数字型,日期和时间,字符串类型(总结)


    mysql数据类型:数字型,日期和时间,字符串类型

    摘要

    MySQL中定义数据字段的类型对数据库的优化是非常重要的;
    MySQL支持多种类型,大致可以分为三类,如下。
    • 数字类型
      • 整数:tinyint、smallint、mediumint、int、bigint
      • 浮点数:float、double、real(实数)、decimal(小数)
    • 日期和时间:date、time、datetime、timestamp、year
    • 字符串类型
      • 字符串:char、varchar
      • 文本:tinytext、text、mediumtext、longtext
    每个类型都强制数据满足该数据类型预先确定的一组规则,例如大小、类型及格式。
     

    关键词

      数字型   日期和时间类型   字符串类型
     

    正文

    1.数字型
      1.一张图解释,数字型的基本信息
        
     
    2.日期和时间类型
      1.一张图解释
        
      2.详解
        1.注意:每种日期和时间类型都有一个有效范围。如果插入的值超出相应范围,系统会报错并将相应的零值插入到数据库中,各个类型的零值请看上表。
        2.YEAR类型用4位数表示年份。范围从1901~2155,插入超范围的值时系统报错并插入0000。
        3.DATE类型用YYYY-MM-DD形式显示日期。范围从1000-01-01~9999-12-31插入超范围的值时系统报错并插入零值。此类型除了可接受YYYY-MM-DD和YYYYMMDD格式的输入外,还可以识别其它一些不严格的语法格式,例如YYYY/MM/DD、YYYY.MM.DD等其他标点符号作为间隔的形式日期值的输入。
        4.TIME类型用HH:MM:SS形式显示时间。其中MM和SS的取值范围是0~59,HH的取值范围比较特别其取值范围是0~838,一般来讲小时数的范围是0~23,但是为了满足特殊情况的需要,MySQL扩大了TIME类型的范围,而且可以接受负数。TIME类型支持D HH:MM:S格式的时间表达字串,D表示天数,取值范围0~34。例如,输入30 21:15:26,系统会将小时部分按30*24+21转换为 741:15:26。除了标准的输入方式HH:MM:SS外,此类型还可以接受一些非标准的输入方式,例如,输入12,系统会转换为00:00:12、输入1212,系统会转换为00:12:12、输入121212,系统会转换为12:12:12等。
        5.DATETIME类型用YYYY-MM-SS HH:MM:SS形式显示日期与时间。范围从1000-01-01 00:00:00~9999-12-31 23:59:59 插入超范围的值时,系统报错并插入零值(0000-00-00 00:00:00)。此类型除了可接受YYYY-MM-SS HH:MM:SS格式的输入外,还可以识别YYYYMMSSHHMMSS形式的输入值。例如,输入20170117174856,系统会转换为2017-01-17 17:48:56。
        6.TIMESTAMP类型情况与DATETIME类型接近,但是它的取值范围要比DATETIME类型窄很多,范围从19700101080001~20380119111407(1970-01-01 08:00:01~2038-01-19 11:14:07)。**另外,TIMESTAMP类型还有一个特别之处,那就是它的值的时间部分是根据时区来显示的,例如在东八区插入的TIMESTAMP类型值2017-01-16 18:04:25,在东七区的时间部分会显示17:04:25,而在东九区则变为19:04:25,对于这一点我们要特别留意。**
        7.我们在选择日期与时间数据类型时,请根据实际需求选择相应的类型,一般应选择刚好够用最好,这样可节省系统资源。例如只需要知道日期的选择DATE类型、需要同时知道日期与时间的就选择DATETIME类型、仅仅需要记录时间的则选择TIME类型等。
     

    字符串类型

      1.一张图解释
        
      2.char和varchar
        3.相同点:char和varchar类型都是在创建表时指定最大长度。其基本形式是:字符串类型(M)例如:char(4)就是指定char类型且它的最大长度是4。
        4.不同点:
          1.char类型的长度是固定的,在创建表时就指定了,其最大长度是0-255的任意值。例如:char(100)就是指定char类型的长度为100.
          2.varchar类型的长度是可变的,在创建时指定了最大长度。定义时,其最大值可以取0-65535之间的任意值。指定varchar类型的最大值之后,其长度可以在0到最大长度之间。例如:varchar(100)的最大长度是100.但是不是每条记录都要占100条位置,而是在这个最大范围内使用多少分配多少。varchar类型实际占用的空间为字符串的实际长度+1.这样,可以有效地节约系统的空间。
      3.text类型
        1.text类型是一种特殊的字符串类型。text只能保存字符数据,如新闻的内容等。
        2.text类型包括tinytext,text,mediumtext,longtext
        3.这种字符串类型实际中用的并不是很多,一般用来直接存储一个比较大的文本,不如说一篇文章,一篇新闻
      4.简单总结:经常变化的字段用varchar;知道固定长度的用char;尽量用varchar;超过255字符的只能用varchar或者text;能用varchar的地方不用text。
     

     总结

      通过对每种数据类型的用途,物理存储,表示范围等有一个概要的了解。这样在面对具体应用时,就可以根据相应的特来来选择合适的数据类型,使得我们能够争取在满足应用的基础上,

    用较小的存储代价换来较高的数据库性能

     
     
     
     
     
  • 相关阅读:
    RedisTemplate实现事物问题剖析和解决
    PO BO VO DTO POJO DAO概念及其作用(附转换图)
    Java 应用程序设计规范
    Java web url 规范
    Java 中 Map与JavaBean实体类之间的相互转化
    使用Java 8中的Stream
    [转]http://lua-users.org/wiki/LpegTutorial
    [转]LUA元表
    LPEG
    [转]LUA 学习笔记
  • 原文地址:https://www.cnblogs.com/wobuchifanqie/p/6768941.html
Copyright © 2020-2023  润新知