MySQL字段类型最全解析

前言:

要了解一个数据库,我们必须了解其支持的数据类型。MySQL 支持大量的字段类型,其中常用的也有很多。前面文章我们也讲过 int 及 varchar 类型的用法,但一直没有全面讲过字段类型,本篇文章我们将把字段类型一网打尽,讲一讲常用字段类型的用法。

常用的字段类型大致可以分为数值类型字符串类型日期时间类型三大类,下面我们按照分类依次来介绍下。

1.数值类型

数值类型大类又可以分为整型浮点型定点型三小类。

整型主要用于存储整数值,主要有以下几个字段类型:

MySQL字段类型最全解析

整型经常被用到,比如 tinyint、int、bigint 。默认是有符号的,若只需存储无符号值,可增加 unsigned 属性。

int(M)中的 M 代表最大显示宽度,并不是说 int(1) 就不能存储数值10了,不管设定了显示宽度是多少个字符,int 都是占用4个字节,即int(5)和int(10)可存储的范围一样。

存储字节越小,占用空间越小。所以本着最小化存储的原则,我们要尽量选择合适的整型,例如:存储一些状态值或人的年龄可以用 tinyint ;主键列,无负数,建议使用 int unsigned 或者 bigint unsigned,预估字段数字取值会超过 42 亿,使用 bigint 类型。

浮点型主要有 float,double 两个,浮点型在数据库中存放的是近似值,例如float(6,3),如果插入一个数123.45678,实际数据库里存的是123.457,但总个数还以实际为准,即6位,整数部分最大是3位。float 和 double 平时用的不太多。

类型

大小

用途

FLOAT

4 字节

单精度浮点数值

DOUBLE

8 字节

双精度浮点数值

定点型字段类型有 DECIMAL 一个,主要用于存储有精度要求的小数。

类型

大小

用途

DECIMAL

对DECIMAL(M,D) ,如果M>D,为M+2字节 否则为D+2

精确小数值

DECIMAL 从 MySQL 5.1 引入,列的声明语法是 DECIMAL(M,D) 。NUMERIC 与 DECIMAL 同义,如果字段类型定义为 NUMERIC ,则将自动转成 DECIMAL 。

对于声明语法 DECIMAL(M,D) ,自变量的值范围如下:

M是最大位数(精度),范围是1到65。可不指定,默认值是10。D是小数点右边的位数(小数位)。范围是0到30,并且不能大于M,可不指定,默认值是0。

例如字段 salary DECIMAL(5,2),能够存储具有五位数字和两位小数的任何值,因此可以存储在salary列中的值的范围是从-999.99到999.99。

2.字符串类型

字符串类型也经常用到,常用的几个类型如下表:

MySQL字段类型最全解析

其中 char 和 varchar 是最常用到的。char 类型是定长的,MySQL 总是根据定义的字符串长度分配足够的空间。当保存 char 值时,在它们的右边填充空格以达到指定的长度,当检索到 char 值时,尾部的空格被删除掉。varchar 类型用于存储可变长字符串,存储时,如果字符没有达到定义的位数,也不会在后面补空格。

char(M) 与 varchar(M) 中的的 M 表示保存的最大字符数,单个字母、数字、中文等都是占用一个字符。char 适合存储很短的字符串,或者所有值都接近同一个长度。例如,char 非常适合存储密码的 MD5 值,因为这是一个定长的值。对于字符串很长或者所要存储的字符串长短不一的情况,varchar 更加合适。

我们在定义字段最大长度时应该按需分配,提前做好预估,能使用 varchar 类型就尽量不使用 text 类型。除非有存储长文本数据需求时,再考虑使用 text 类型。

BLOB 类型主要用于存储二进制大对象,例如可以存储图片,音视频等文件。日常很少用到,有存储二进制字符串时可以考虑使用。

3.日期时间类型

MySQL支持的日期和时间类型有 YEARTIMEDATEDATETIMETIMESTAMP,几种类型比较如下:

MySQL字段类型最全解析

涉及到日期和时间字段类型选择时,根据存储需求选择合适的类型即可。

关于 DATETIME 与 TIMESTAMP 两种类型如何选用,可以按照存储需求来,比如要求存储范围更广,则推荐使用 DATETIME ,如果只是存储当前时间戳,则可以使用 TIMESTAMP 类型。不过值得注意的是,TIMESTAMP 字段数据会随着系统时区而改变但 DATETIME 字段数据不会。总体来说 DATETIME 使用范围更广。

总结:

本篇文章主要介绍了 MySQL 中常用的字段类型,平时用到的字段类型基本都在这里了,以一张思维导图总结如下:

MySQL字段类型最全解析

本文转自MySQL技术前线,仅用于技术分享。

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/35735.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
小二小二加盟商
上一篇 2022年4月27日 00:14
下一篇 2022年4月27日 00:15

相关推荐

  • 9个相见恨晚的微信小程序,免费又实用,满足生活各种需求

    已经很久没给大家分享小程序了,今天给大家带来9个相见恨晚的微信小程序,免费又实用,满足你的生活各种需求。01*智能修复老照片软件这是一个免费修复老照片工具,支持给黑白照片上色和修复模糊人像。只要上传图片…

    2022年4月27日 科技动态
    0230
  • 花5分钟规范「代码注释」

    序 【注释】从技术上来说没有对错,理论上,你想怎么写就怎么写,你爱怎么写就怎么写! 但它确实也会对我们造成影响,尤其是在多人协同开发的系统中。杂乱的注释也会让你或你的队友头疼~ 所以,我们需要规范一下注…

    2022年5月13日
    0350
  • 9个暗藏惊喜的微信小程序,硬核又实用,请大家低调使用

    我发现大家都喜欢用小程序,可能是因为无需安装就能使用,比较方便。今天我就来分享9个暗藏惊喜的微信小程序,硬核又实用,还请大家低调使用。01*百科知识词典特色:在线版“百科全书”。顾名思义,这是一个百科大词…

    2022年4月27日 科技动态
    0240
  • 8个压箱底的宝藏App,实用又强大,手机秒变黑科技

    突然想问大家一个问题,你们的手机上都有哪些好用的App?今天我就来推荐8个压箱底的宝藏App,实用又强大,让你的手机秒变黑科技。01*秒启动特色:1秒启动手机应用。现在的很多App启动时,都要等待5秒的开屏广告,有…

    2022年4月26日 科技动态
    0179
  • 推荐10款Windows实用软件,让你的电脑更好用

    软件推荐(第29期):最近我又挖掘了不少好用软件,下面就给大家分享一下,这10个赞不绝口的Windows神级软件,让你的电脑好用数倍不止,每一款都很实用。01*UPUPOO下载地址:http://www.upupoo.com/UPUPOO里面包含…

    2022年4月27日 科技动态
    0158
  • 分享10款电脑必备的黑科技软件

    软件推荐(第30期):相信大家电脑上有很多非常实用的软件,可能一直舍不得分享,那么今天我就来推荐10款电脑必备的黑科技软件,每一个都堪称神器,千万不要错过。01.一键录音下载地址:https://www.xunjieshipin.c…

    2022年4月27日 科技动态
    0320
  • 号外!玩转Python字符串的7大秘籍

    字符串是Python中最常用、最基本的数据类型。Python对字符串的处理内置了很多高效的函数,在很多情况下,Python对字符串处理的效率要远高于其他编程语言。下面是我总结的常用的秘籍。欢迎大家一起学习~字符串赋值…

    2022年4月27日
    0229
  • 推荐8款实用手机App

    手机上除了每天常用的软件,你还知道有哪些好用的App吗?今天就给大家带来8个冷门逆天的实用App,款款精挑细选,让手机秒变黑科技。01 万能联播这是爱奇艺出品的万能播放器,自动扫描手机里的音视频文件,支持多种…

    2022年4月27日 科技动态
    0186

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息