MySQL中的数据类型 [数值型、字符串型、时间日期型]
| 类型 | 数据大小 | 类型 (无符号:unsigned) | 数据大小 | 存储空间 |
| tinyint | -128 到 127 | tinyint unsigned | 到 255 | 1 |
| smallint | -32768 到 32767 | smallint unsigned | 0 到 65535 | 2 |
| mediumint | -8388608 到 8388607 | mediumint unsigned | 到 16777215 | 3 |
| int 或 integer | -2147483648 到 2147483647 | int unsigned 或 integer unsigned | 到 4294967295 | 4 |
| bigint | -9223372036854775808 到 9223372036854775807 | bigint unsigned | 0 到 18446744073709551615 | 8 |
| 类型 | “ 零 ” 值 | 存储空间 |
| time | '00:00:00' | 3 |
| date | '0000-00-00' | 3 |
| datetime | '0000-00-00 00:00:00' | 8 |
| year | 0000 | 1 |
| timestamp | 0000000000000000 | 4 |
- varchar(M):1. 当字符串长度M小于255时,用额外的1个字节来记录长度,存储空间L+1。[L为值的长度]
2. 当字符串长度M大于255时,用额外的2个字节来记录长度,存储空间L+2。[L为值的长度]
- 比如:char(255)和varchar(255),在存储字符串"hello world"时:
char会用255个字节的空间放那个11个字符;
varchar就不会用255个,它先计算字符串长度为11,然后再加上一个记录字符串长度的字节,一共用12个字节存储,这样varchar在存储不确定长度的字符串时会大大减少存储空间。
- 从效率上考虑,固定长度,存储空间一次性分配,CHAR更好(长度较短的字段:门牌号等、固定长度的字段:性别、身份证号、手机号等)。
- 从空间上考虑,可变长度,根据长度动态调整存储空间,VARCHAR更好。
- 下面的表显示了将各种字符串值保存到CHAR(4)和VARCHAR(4)列后的结果,说明了CHAR和VARCHAR之间的差别:
| 值 | char(4) | 存储空间 btyes | varchar(4) | 存储空间 btyes |
| '' | ' ' | 4 | '' | 1 |
| 'ab' | 'ab ' | 4 | 'ab ' | 3 |
| 'abcd' | 'abcd' | 4 | 'abcd' | 5 |
| 'abcdefgh' | 'abcd' | 4 | 'abcd' | 5 |
另外:
| 类型 | 存储空间 |
| tinyint | 1 |
| smallint | 2 |
| mediumint | 3 |
| int,integer | 4 |
| bigint | 8 |
| float(p) | 如果0 <= p <= 24为4个字节, 如果25 <= p <= 53为8个字节 |
| double | 8 |
| decimal(M,D),numeric(M,D) | 变长 |
| bit(M) | 大约(M+7)/8个字节 |

- 实际上小数数值只有两种数据类型:float 和 decimal,分别是近似数值和精确数值。
- 其他小数类型,都可以使用float和decimal来替代,例如,双精度(double precision)数据类型等价于 float(53),real等价于float(24)。
- numeric是 decimal的同义词,应该避免在程序中直接使用 double precision、real和numeric,而是用 float(24) 、float(53)和decimal 代替。
| 类型 | 存储空间 (字节) |
| char(M) | M,0 <= M <= 255 |
| varchar(M) | L+1 或 L+2,其中L <= M 且0 <= M <= 65532 |
| binary(M) | M,0 <= M <= 255 |
| varbinary(M) | L+1个字节,其中L <= M 且0 <= M <= 255 |
| tinyblob tinytext |
L+1个字节,其中L < 28 |
| blob,text | L+2个字节,其中L < 216 |
| mediumblob mediumtext |
L+3个字节,其中L < 224 |
| longblob longtext |
L+4个字节,其中L < 232 |
| enum('value1','value2',...) | 1或2个字节,取决于枚举值的个数(最多65,535个值) |
| set('value1','value2',...) | 1、2、3、4或者8个字节,取决于set成员的数目(最多64个成员) |

<wiz_tmp_tag id="wiz-table-range-border" contenteditable="false" style="display: none;">
MySQL中的数据类型 [数值型、字符串型、时间日期型]的更多相关文章
- MySQL 中的数据类型介绍(转)
据我统计,MySQL支持39种(按可使用的类型字段统计,即同义词也作多个)数据类型.下面的介绍可能在非常古老的mysql版本中不适用. 转载出处:http://blog.csdn.net/anxpp/ ...
- MySQL中各种数据类型的长度及在开发中如何选择
接触MySQL这个数据库大概快要两年了,不过由于没有特别深入系统的去学习,大多也是停留在一知半解的状态.今天在工作中刚好碰到了表设计的问题,顺便写篇博客,把MySQL中数据类型和字段类型选择这方面给弄 ...
- 存储引擎和表的操作(mysql中的数据类型、完整性约束)
一.存储引擎 .概念 MySQL中的数据用各种不同的技术存储在文件(或者内存)中.这些技术中的每一种技术都使用不同的存储机制.索引技巧.锁定水平并且最终提供广泛的不同的功能和能力. 通过选择不同的技术 ...
- 【个人笔记】《知了堂》MySQL中的数据类型
MySQL中的数据类型 1.整型 MySQL数据类型 含义(有符号) tinyint(m) 1个字节 范围(-128~127) smallint(m) 2个字节 范围(-32768~32767) ...
- 抛砖系列之-MySQL中的数据类型JSON
今天介绍一个MySQL中的数据类型-JSON,相信大家对JSON都不陌生,在日常工作中使用到的频率也很高,话不多说,直接开始. 何谓JSON 看下RFC文档对于JSON的描述 1.基于 JavaScr ...
- MySQL 中的数据类型介绍
1.MySQL 数据类型 MySQL中定义数据字段的类型对你数据库的优化是非常重要的. MySQL支持多种类型,大致可以分为三类:数值.日期/时间和字符串(字符)类型. 2.数值类型(12) 2.1. ...
- 存储引擎,MySQL中的数据类型及约束
存储引擎,MySQL中的数据类型及约束 一.存储引擎 1.不同的数据应该有不同的处理机制 2.mysql存储引擎 Innodb:默认的存储引擎,查询速度叫myisam慢,但是更安全 支持事务, ...
- MySQL中的数据类型及创建
MySQL创建: 1.创建数据库create database test2; 2.删除数据库drop database test2;3.创建表create table ceshi( ids in ...
- vb.net字符串格式转为日期型
vb.net字符串格式转为日期型 比如 "20080815" 转换为"2008-05-15"Dim a As Date Dim s As String = ...
随机推荐
- 使用docker部署mysql主从复制集群
一.环境搭建 虚拟机环境:centos7 IP: 启动3个容器,一个是master,端口是3307,另外两个是slaver,端口是3308和3309 docker pull mysql:5.7 doc ...
- js判断滚动条是否已到页面最底部或顶部实例
原文 本文实例讲述了js判断滚动条是否已到页面最底部或顶部的方法.分享给大家供大家参考.具体分析如下: 我们经常会看到很多的网站一个返回顶部效果就是当我们滚动条到指定位置时返回顶部出来了,否则就自动隐 ...
- mysql中的utf8mb4、utf8mb4_unicode_ci、utf8mb4_general_ci的关系
mysql中的utf8mb4.utf8mb4_unicode_ci.utf8mb4_general_ci的关系 一.总结 一句话总结: utf8mb4是utf8的超集并完全兼容utf8,能够用四个字节 ...
- mysql数据库学习
1,服务端和客户端 MySQL 包括服务端和客户端,服务端是MySQL server,客户端包括命令行客户端和图形用户客户端: 命令行客户端:mysql,mysqladmin,mysqldump ( ...
- 2.jdk1.8+springboot中http1.1之tcp连接复用实现
接上篇:https://www.cnblogs.com/Hleaves/p/11284316.html 环境:jdk1.8 + springboot 2.1.1.RELEASE + feign-hys ...
- Handler处理消息
UI主线程通过Looper循环查询消息队列UI_MQ,当发现有消息存在时会将消息从消息队列中取出.首先分析消息,通过消息的参数判断该消息对应的Handler,然后将消息分发到指定的Handler进行处 ...
- Grafana添加Zabbix为数据源(二)
接触过grafana的同学肯定会觉得grafana比zabbix的图像灵活好看很多,下面就让我们一起进行grafana的web界面配置 1.鼠标移动到左上角,点击Plugins,然后选择"c ...
- VBA 刷新数据透视表
Sub pjCount() Dim r As Long r = Sheets("Inquery").[A65536].End(xlUp).Row ActiveSheet.Pivot ...
- java ldap用户密码md5加密
在这里不过多介绍ldap,因为这样的文章特别多,这里就简单直接的记录这一个问题. 在springboot中通过引入spring-boot-starter-data-ldap,使用LdapTemplat ...
- vue+npm+Element插件+路由
首先安装node.js 之后使用管理员输入命令 然后,就可以使用 npm 命令安装了: npm install -g @vue/cli安装完后,打开命令行窗口,会有一个 vue 命令:vue -v v ...