说明:本文是作者对MySQL数据库数据存储类型的小小总结。

Numeric Type (数字类型)

1、TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT
主要根据存储字节长度不一样划分:

  • TINYINT:1字节

  • SMALLINT:2字节

  • MEDIUMINT:3字节

  • INT:4字节

  • BIGINT:8字节

如果不需要符号数时,建议加上unsigned,会扩充存储长度一倍,提高存储性能。如TINYINT UNSIGNED(0~255)/TINYINT(-128~127)。

2、DECIMAL/NUMERIC
DECIMAL与NUMERIC一样,二进制形式存储数字类型,如DECIMAL(4,2)表示存储一个小数点后两位总共4位精度的数字,范围是-99.99~99.99。总位数最大数字是65。

3、FLOAT和DOUBLE
FLOAT是4字节存储,DOUBLE双精度是8字节存储。FLOAT(6,4)表示存储一个小数点后四位总共6位精度的数字,如果小数位有超出则四舍五入。如把99.0000990存进去,则实际上存的是99.0001,这会让数字失真,所以对于银行账号金额要求高精度的,则可以换成双精度来存储,或者对原数字小数点左移存储。

String Type (字符类型)

1、CHAR和VARCHAR
CHAR是固定字符长度,且最大字符长度为255=2e8-1,处理速度比VARCHAR快,但容易浪费存储空间。如CHAR(10)表示固定分配10个字符长度存储空间,当存储'PHP'时,就浪费了7个字符长度的存储空间。对于字符后尾的空格,CHAR需要做处理。
VARCHAR是可变长度,根据字符实际长度分配存储空间,最大字符长度为65535=2e16-1。VARCHAR(10)表示最大存储10个字符长度的字符串,存储'PHP'时只分配3个存储空间,节约存储空间。
默认使用InnoDB引擎时,使用VARCHAR比较好。一般用VARCHAR类型比较多。

2、BINARY和VARBINARY
BINARY/VARBINARYCHAR/VARCHAR类似,只不过BINARY/VARBINARY存储的是二进制字符,长度也表示字节长度而不是字符长度(ASCII编码一个英文字母1个字节一个汉字2个字节;UTF-8编码一个英文字母1个字节一个汉字3个字节)。

3、BLOB和TEXT
BLOB存储大数据量的二进制数据,比如一张图片。BLOB分为:TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB,根据存储字节最大长度分类。
TEXT存储大数据量的字符串数据,TEXT分为:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT,根据存储文本最大长度分类。

4、ENUM
枚举类型,每一个值都有对应的索引index。最大两个字节存储,65535个不同成员。注意的是:
表中字段:numbers ('0', '1', '2')
insert into test(numbers) values (2),('2'),('3');
select * from test;
会返回:
numbers

  • 1

  • 2

  • 2

这说明,存储整形2时把2当做索引存的是第二个值'1',存储字符'2'时就是字符'2',存储字符'3'时把'3'当做索引3,存的是'2'。

5、SET
集合类型,与ENU类似,最多包含64个成员。

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');
SELECT * FROM myset;

会顾虑掉重复数据:

Date and Time Type (日期和时间类型)

DATE、TIME、DATETIME、TIMESTAMP、YEAR
默认格式为:

  • DATE: 1000-01-01 ~ 9999-12-31

  • TIME: 00:00:01 ~ 23:59:59

  • DATETIME: 1000-01-01 00:00:00 ~ 9999-12-31 59:59:59

  • TIMESTAMP: 1970-00-01 00:00:00 ~ 2038-01-19 03:14:07

  • YEAR: 0001 ~ 9999

其中,比较方便的一个是timestamp,它可以根据时区不同进行转换,很好用。

MySQL学习笔记之数据存储类型的更多相关文章

  1. Android 学习笔记之数据存储SharePreferenced+File

    学习内容: Android的数据存储.... 1.使用SharedPreferences来保存和读取数据... 2.使用File中的I/O来完成对数据的存储和读取...   一个应用程序,经常需要与用 ...

  2. MySQL学习笔记:Engine存储引擎

    在使用Mysql建表过程中,有时候会遇到一些奇怪的现象.例如,如何插入数据就是查询不到数据,此时可能是建表的存储引擎设置成为engine=blackhole的原因. 1.engine=innodb 提 ...

  3. android菜鸟学习笔记18----Android数据存储(二)SharedPreferences

    数据存储的方式,有比直接文件读写更加简便的方式,那就是操作SharedPreferences. SharedPreferences一般用于存储用户的偏好设定,暂时不支持多进程操作. SharedPre ...

  4. mysql学习笔记一 —— 数据的增删改查

    1.连接mysql mysql 直接回车(是以root身份,密码空,登陆的是本机localhost) [root@www mysql]# mysql -uroot -p123 -S /var/lib/ ...

  5. MySQL学习笔记七:存储引擎

    1.MySQL存储引擎的设计采用“插件式”方案,用户可以很方便地选择使用哪种存储引擎,想使用mysql没有提供的引擎时,可以自己安装进去. 查看支持的存储引擎 mysql> show engin ...

  6. MySQL学习笔记(四):存储引擎的选择

    一:几种常用存储引擎汇总表 二:如何选择 一句话:除非需要InnoDB 不具备的特性,并且没有其他办法替代,否则都应该优先考虑InnoDB:或者,不需要InnoDB的特性,并且其他的引擎更加合适当前情 ...

  7. android菜鸟学习笔记20----Android数据存储(四))Android数据库操作

    Android内置了一个名为SQLite的关系型数据库,这是一款轻量型的数据库,操作十分简便.SQLite与别的数据库不同的是,它没有数据类型.可以保存任何类型的数据到你所想要保存的任何表的任何列中. ...

  8. android菜鸟学习笔记17----Android数据存储(一)文件读写

    假如有如下需求,要求能够记录用户输入的用户名和密码,下次登录时,能直接获取之前保存的用户名密码,并在相应的EditText中显示. 要保存用户输入的数据,最先想到的应该就是文件读写了. 通过对andr ...

  9. Windows Phone 学习笔记(一) 数据存储

    独立存储设置IsolatedStorageSetting private IsolatedStorageSettings _appSettings; public MainPage() { Initi ...

随机推荐

  1. nginx 学习八 高级数据结构之基数树ngx_radix_tree_t

    1 nginx的基数树简单介绍 基数树是一种二叉查找树,它具备二叉查找树的全部长处:检索.插入.删除节点速度快,支持范围查找.支持遍历等. 在nginx中仅geo模块使用了基数树. nginx的基数树 ...

  2. MySQL Router 测试使用 转

    MySQL Router 测试使用 . 特性 MySQL Router 并没有包括一些特别新的特性, 总体上看中规中矩, 不过 first-available 和插件两个特性挺有意思, 后续会进行讲解 ...

  3. c# 操作word

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...

  4. Android 自学之选项卡TabHost

    选项卡(TabHost)是一种非常实用的组件,TabHost可以很方便地在窗口上放置多个标签页,每个标签页相当于获得了一个与外部容器相同大小的组建摆放区域.通过这种方式,就可以在一个容器中放置更多组件 ...

  5. VMware系统运维(一)安装Esxi

    1.下载ISO文件,开始安装,如图1,直接按回车进行安装. 图1 2.按回车键继续安装,如图2所示 图2 3.选择要安装系统的磁盘,按回车继续,如图3所示 图3 4.选择对应的键盘语言,按回车继续,如 ...

  6. 用css做类似表格的布局

    --2013年6月24日12:08:49 今天突然不想用table了,就在园子里找了几个用css的解决办法,直接上代码: --1.html代码: <!DOCTYPE html PUBLIC &q ...

  7. VC操作Excel之基本操作

    // 变量的定义 _Application app; Workbooks books; _Workbook book; Worksheets sheets; _Worksheet sheet; Ran ...

  8. Java操作字符串的工具类

    操作字符串的工具类 import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.PrintStre ...

  9. hdu 4251 划分树

    思路:裸的划分树 #include<iostream> #include<algorithm> #include<cstdio> #include<cmath ...

  10. CSS中link和@import的区别是:

    Link属于html标签,而@import是CSS中提供的 在页面加载的时候,link会同时被加载,而@import引用的CSS会在页面加载完成后才会加载引用的CSS @import只有在ie5以上才 ...