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。
 

总结

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

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

 
 
 
 
 

mysql学习1:数据类型:数字型,日期和时间,字符串类型(总结)的更多相关文章

  1. MySQL中的数据类型 [数值型、字符串型、时间日期型]

    MySQL中的数据类型 [数值型.字符串型.时间日期型] MySQL中各数据类型 1. 数值类型(整型) 类型 数据大小 类型 (无符号:unsigned) 数据大小 存储空间 tinyint -12 ...

  2. toLocaleTimeString()方法在IE和谷歌浏览器上 根据本地时间格式,把 Date 对象的时间部分(不含日期)转换为“时间字符串”存在区别

    这两天修改一个bug,发现一个问题:  toLocaleTimeString()方法在IE和谷歌浏览器上 根据本地时间格式,把 Date 对象的时间部分(不含日期)转换为“时间字符串”存在区别.方法原 ...

  3. MYSQL学习笔记——数据类型

    mysql的数据类型可以分为三大类,分别是数值数据类型.字符串数据类型以及日期时间数据类型. 数值数据类型                                               ...

  4. GO语言学习——基本数据类型——整型、浮点型、复数、布尔值、fmt占位符

    基本数据类型 整型 整型分为以下两个大类: 按长度分为:int8.int16.int32.int64 对应的无符号整型:uint8.uint16.uint32.uint64 其中,uint8就是我们熟 ...

  5. R语言学习 第十一篇:日期和时间

    R语言的基础包中提供了三种基本类型用于处理日期和时间,Date用于处理日期,它不包括时间和时区信息:POSIXct/POSIXlt用于处理日期和时间,其中包括了日期.时间和时区信息.R内部在存储日期和 ...

  6. Python 学习 第15篇:日期和时间

    datetime模块中包含五种基本类型:date.time.datetime.timedelta和tzinfo,tz是time zone的缩写,tzinfo用于表示时区信息. 一,date类型 dat ...

  7. Python学习进程(11)日期和时间

        本节介绍Python应用程序处理时间和日期的方式.其中转换日期格式是最常用的功能.     (1)获取时间戳: Python 提供了一个 time 和 calendar 模块可以用于格式化日期 ...

  8. MySQL学习4 - 数据类型一

    介绍 一.数值类型 二.浮点型 验证三种类型建表 验证三种类型的精度 三.日期类型 综合练习: 介绍 存储引擎决定了表的类型,而表内存放的数据也要有不同的类型,每种数据类型都有自己的宽度,但宽度是可选 ...

  9. MySQL学习5 - 数据类型二.md

    一 字符类型 二 枚举类型和集合类型 一 字符类型 #官网:https://dev.mysql.com/doc/refman/5.7/en/char.html #注意:char和varchar括号内的 ...

  10. MySQL学习笔记--数据类型

    一.数据类型(内容参考<SQL学习指南>)不完整 1.文本类型 文本类型 最大字节数 tinytext 255 text 65535 varchar 65536 mediumtext 16 ...

随机推荐

  1. unity 解决ScrollRect嵌套滚动问题

    在子级有ScrollRect组件的对象添加以下脚本: using UnityEngine; using System.Collections; using UnityEngine.UI; using ...

  2. 21 week4 submit buidAndRun() node-rest-client

    . 我们想实现一个提交代码的功能 这个功能有nodeserver 传到后边的server 验证 在返回给nodeserver 我们稍微修改一下ui ATOM修改文件权限不够 用下面命令 我们 Cont ...

  3. 前端CSS3笔记

    第1章CSS3简介 如同人类的的进化一样,CSS3是CSS2的“进化”版本,在CSS2基础上,增强或新增了许多特性, 弥补了CSS2的众多不足之处,使得Web开发变得更为高效和便捷. 1.1   CS ...

  4. js 乘法 4.39*100 出现值不对问题解决

    https://www.jianshu.com/p/a026245661bb //除法函数,用来得到精确的除法结果 //说明:javascript的除法结果会有误差,在两个浮点数相除的时候会比较明显. ...

  5. oracle 连接池参数

    后来排查出数据库监听异常,发现是ORA-12519拒绝错误.后来发现是数据的连接池达到的极致. 具体解决方案如下: --首先检查process和session的使用情况,在sqlplus里面查看. S ...

  6. akka之种子节点

    AKKA提供的cluser功能能够很便捷的创建一个分布式应用,在使用cluster时需要配置seed nodes节点,这里对seed nodes节点做一下介绍. AKKA seed nodes 和普通 ...

  7. 关于log4j:WARN No appenders could be found for logger (org.apache.hadoop.metrics2.lib.MutableMetricsFactory).的问题

    解决办法(非长久之计,折中) 将该方法插入到main函数中,可以自行打印日志信息了 BasicConfigurator.configure(); //自动快速地使用缺省Log4j环境.原文链接:htt ...

  8. springboot-day01-引入基础

    1. 今日大纲 1. 了解Spring的发展 2. 掌握Spring的java配置方式 3. 学习Spring Boot 4. 使用Spring Boot完成CRUD 2. Spring的发展 2.1 ...

  9. MO拆分计划行程序中写入PRODUCTIONORDERS表数据出现重复导致报错(BUG)20180502

    错误提示:ORA-00001: 违反唯一约束条件 (ABPPMGR.C0248833319_6192)ORA-06512: 在 "STG.FP_MO_SPLIT", line 19 ...

  10. 修改Eclipse主题与Eclipse中使用SVN

    自从开始IDEA后,很久没用eclipse了,有位老同学问我eclipse中如何使用SVN?我就打开eclipse试试,白光太刺眼了~作为强迫症修改下主题.结果如下: 修改完编辑的背景颜色,并没有很好 ...