说明:通俗的理解:1字节的8位,即1byte=8bit,而这个1byte叫做长度范围,范围的算法是使用bit去求,比如8bit的长度范围是2的8次方,但是在数据库中的类型上是有区分有符号和无符号的,默认为有符号,所以,长度的算法就要减去一个次方,得到的数加上负号之后就是最左边的数,然后在正数上减去1之后就是最右边的数;当为无符号时,就是正数,直接2的8次方得到的数减去1,至于为什么减1,包括0,可以这么去理解。

1、整数

TINYINT:8bit存储空间

SMALLINT:16bit存储空间

MEDIUMINT:24bit存储空间

INT:32bit存储空间

BIGINT:64bit存储空间

分为:

SIGNEN:有符整数,可存储正数和负数,如TINYINT SIGNED表示的范围是 -127 ~ 128(注意:默认为有符号整数,且显示位宽与长度范围是不同的概念)

UNSIGNED:无符整数,只能存储正数,但是表示的值是有符整数的两倍, 如 TINYINT UNSIGNED 表示的范围是 0 ~ 255

有符整数和无符整数只有表示的值大小上的区别,存储空间和效率上都是一样的

2、实数

DECIMAL:可表示比 BIGINT 还大的正数,保存时可以指定整数长度和小数位数,如DECIMAL(18,9)表示总长18位,小数点后9位,一共占用9 Byte,小数点前4 Byte,小数点1 Byte, 小数点后4 Byte, 一般用于存储精确数据,如银行账目

FLOAT:32 bit, 0~23精度

DOUBLE:64 bit,  24~53精度

DOUBLE和FLOAT比起DECIMAL,占用的存储更少,但是精度没有DECIMAL高

3、字符串

CHAR:

定长字符串,最大长度为255,MySql会分配固定的存储空间来存储CHAR,一般来讲用在需要经常执行长度经变化的UPDATE,但最大长度和平均长度相近的列上

CHAR在获取值时,会将末尾空格删除,但是在比较值时,末尾的空格则会保存

VARCHAR:

变长字符串,最大长度为65535,MySql会分配字符串实际长度的空间来存储VARCHAR,一般来讲用在不需要经常执行列值长度变化的UPDATE,但是最大长度又远大于平均长度的列上,因为当列值的长度变化时(例如某列从"Jack" => "I want to gank"),需要重新分配需要的存储空间,会造成额外的性能开销.

CHAR和VARCHAR总是会使用字符编码的最大长度来作为单位存储空间,这是为了保证缓存中有足够的空间来存储字符串,例如使用UTF8,虽然UTF8是变长字符集(英文1Byte,中文3Byte),但是VARCHAR(10)仍然会占用30Bytes空间,即使里面一个中文字也没有。

另外,VARCHAR会比原长度额外占用1~2个字节,用来表示字符串的长度,当字符串长度小于255时占用1Byte, 否则占用2Byte

查询时,CHAR去除末尾空格

WHERE字句比较字符串时,CHAR保留末尾空格

关于二者的效率:

  • UPDATE时,CHAR的效率会高于VARCHAR的效率,因为VARCHAR是不定长的,当数据长度改变时,需要重新分配存储空间

BLOB和TEXT:

BLOB和TEXT的唯一区别是BLOB保存二进制类型而且没有字符集好排序规则,而TEXT保存字符文本,且有字符集和排序规则

它们的排序规则按照max_short_length规定长度的前若干个字符进行排序

4、日期和时间类型

DATETIME:将日期保存为YYYYMMDDHHMMSS格式,范围从1001~9999年,占用空间8Byte

TIMESTAMP:将日期保存为Unix时间戳,范围从1970~2038年, 占用空间4Byte,并且和时区相关,它的特性是当插入没有定义TIMESTAMP的列时,MySql会自动将时间戳保存为当前时间,所以一般可用于记录最后登录时间等。

5、位集数据类型

BIT:最大64bit,一般用于保存一个true/false值,如BIT(1),占用1bit,远小于使用字符表示

SET:用于保存多个true/false值,可用于权限管理

6、枚举

ENUM:类似于SET,但是只能插入1个值,一般可用来表示性别等唯一且范围固定的属性(男,女..)

参考:

http://www.cnblogs.com/zemliu/archive/2012/08/14/2637346.html(以上内容转自此篇文章)

MySql基本数据类型(转)的更多相关文章

  1. MySQL数据库3 - MySQL常用数据类型

    一. MySql常用数据类型 数据类型:整数(tinyint smailint int bigint) 定点数 decimal(p,s) ------ 小数点位置固定的       ---> 数 ...

  2. Mysql常用数据类型

    Mysql常用数据类型 数字: 字符串: 时间:

  3. MySQL日期数据类型、时间类型使用总结

    MySQL日期数据类型.时间类型使用总结 MySQL日期数据类型.MySQL时间类型使用总结,需要的朋友可以参考下.   MySQL 日期类型:日期格式.所占存储空间.日期范围 比较. 日期类型    ...

  4. MySQL日期数据类型、MySQL时间类型使用总结

    MySQL:MySQL日期数据类型.MySQL时间类型使用总结 MySQL 日期类型:日期格式.所占存储空间.日期范围 比较. 日期类型 存储空间 日期格式 日期范围 ------------ --- ...

  5. MySQL数据库数据类型之集合类型SET测试总结

    MySQL数据库提供针对字符串存储的一种特殊数据类型:集合类型SET,这种数据类型可以给予我们更多提高性能.降低存储容量和降低程序代码理解的技巧,前面介绍了首先介绍了四种数据类型的特性总结,其后又分别 ...

  6. mysql 的数据类型

    mysql 的数据类型(描述的是字段)三大类:一.整型:1.tinyint(M),其中M是显示宽度,需要配合zerofill,就是前面0填充,存储单位为1个字节(8位),无符文是最大能存储范围0000 ...

  7. MySQL的数据类型(转)

    MySQL的数据类型 1.整数 TINYINT: 8 bit 存储空间 SMALLINT: 16 bit 存储空间 MEDIUMINT: 24 bit 存储空间 INT: 32 bit 存储空间 BI ...

  8. mysql之数据类型

    一.概述:  所谓建表,就是声明列的过程: 数据是以文件的形式放在硬盘中(也有放在内存里的) 列:不同的列类型占的空间不一样 选列的原则:够用又不浪费: 二.mysql的数据类型: 整形:Tinyin ...

  9. MySQL/MariaDB数据类型

    1.为什么要定义MySQL数据类型 定义MySQL数据类型其实就是为了对数据进行分类,实现对不同的分类进行不同的处理 1.使系统能够根据数据类型来操作数据. 2.预防数据运算时出错.例如,通过强大的数 ...

  10. mysql的数据类型和字段属性

    本文内容: 数据类型 数值类型 整数型 浮点型 定点型 日期时间类型 字符串类型 补充: 显示宽度与zerofll 记录长度 字段属性 空\不为空值:NULL.NOT NULL 主键:primary ...

随机推荐

  1. 再遇BGP

    第一次遇到BGP,是在大学的课堂上,现在再次看到它,有种深深的无奈,我只记得它的名字,忘记了它的样子. 那么什么是BGP呢? 翻译过来就是边界网关协议,一个用来网络数据进行选路的路由协议,使用TCP协 ...

  2. 什么是Entitlement

    Entitlement(权限),可以想象成App里用于描述该App可以调用哪些服务的字符串.苹果的操作系统(mac os或者iOS)会通过检查这个串,决定这个应用是否可以调用相关功能.比如iCloud ...

  3. less算宽度 加~ width: calc(~"50% - 35px");

    less算宽度 加~  width: calc(~"50% - 35px");

  4. 小程序02 wxml和wxss

    微信小程序的排版就跟wxml和wxss有关,它们两者相当于HTML和CSS,其中wxml指定了界面的框架结构,而wxss指定了界面的框架及元素的显示样式. 一.wxml 界面结构wxmL比较容易理解, ...

  5. U盘制作安装盘后容量不能恢复的解决方案

    diskpartlist diskselect disk 0/1 --看具体U盘是0还是1clean

  6. docker nginx 负载均衡

    index1.html <html> <head> <title>lb-test</title> </head> <body> ...

  7. Vue通信、传值的多种方式,详解

    Vue通信.传值的多种方式,详解 转自:https://blog.csdn.net/qq_35430000/article/details/79291287 一.通过路由带参数进行传值 ①两个组件 A ...

  8. [LUOGU] P3004 [USACO10DEC]宝箱Treasure Chest

    第一眼:区间DP,可以瞎搞 f[i][j]=max(sum(i,j)-f[i+1][j],sum(i,j)-f[i][j-1]) 提出来就是f[i][j]=sum(i,j)-min(f[i+1][j] ...

  9. linux 部署nginx作为反向代理入口的内核参数/etc/sysctl.conf

    # Kernel sysctl configuration file for Red Hat Linux## For binary values, 0 is disabled, 1 is enable ...

  10. Django框架基础知识05-自定义模板标签与过滤器

    根据一定规则,自己定义出符合需求功能的.用在任何你有需求的地方,因为内置的满足不了我们的需求,不同的东西有不同的定义规则 目前最最重要的就是HOW 一 文件路径配置: templates 存放自定义 ...