MySQL 5.7常见数据类型

——《深入浅出MySQL(第二版)》笔记

数值类型

整数类型 字节 最小值 最大值
TINYINT 1 有符号 -128;无符号 0 有符号 127;无符号 255
SMALLINT 2 有符号 -2^16;无符号 0 有符号 2^16-1;无符号 2^17-1
MEDIUMINT 3 有符号 -2^24;无符号 0 有符号 2^24-1;无符号 2^25-1
INT\INTEGER 4 有符号 -2^32;无符号 0 有符号 2^32-1;无符号 2^33-1
BIGINT 8 有符号 -2^64;无符号 0 有符号 2^64-1;无符号 2^65-1

浮点类型 字节 最大值 最小值
FLOAT 4
DOUBLE 8

定点数类型 字节 描述
DEC(M,D)\DECIMAL(M,D) M+2 最大值取值范围与DOUBLE相同,给定DECIMAL的有效取值范围由M和D决定

位类型 字节 最小值 最大值
BIT(M) 1~8 BIT(1) BIT(8)

整数类型

对于整数类型,MySQL支持在类型名称后面使用(n)的方式指定显示宽度,例如int(5)表示当数值宽度小于5位时,在数字前面填满宽度,如果不显示指定宽度则默认为int(11)。一般配合zerofill使用,就是用'0'填充。

示例:

--创建表t1,有id1和id2两个字段,指定数值宽度分别为int和int(5)
mysql> create table t1 (id1 int,id2 int(5));
mysql> desc t1;

--在id1和id2中都插入数值1
mysql> insert into t1 values (1,1);
mysql> select * from t1;

--分别给id1和id2字段增加zerofill参数
mysql> alter table t1 modify id1 int zerofill;
mysql> alter table t1 modify id2 int(5) zerofill;

设置了宽度限制后,如果插入大于宽度限制的值,不会对插入的数据有任何影响,还是按照类型的书记精度进行保存。这时,宽度格式实际已经没有意义,左边不会再填充任何的“0”字符。

--向表t1的id1中插入1,id2中插入12345678
mysql> insert into t1 values(1,12345678);
mysql> select * from t1;

所有的整数类型都有一个可选属性UNSIGNED(无符号),如果需要在字段里面保存非负数或者需要较大的上限值,可以用此选项。而当一个列指定为zerofill,则MySQL自动为该列添加UNSIGNED属性。

另外,整数类型还有一个独有的AUTO_INCREMENT属性,表示该列的值是自增型。AUTO_INCREMENT值一般从1开始,每行增加1。在插入NULL到一个AUTO_INCREMENT列时,MySQL插入一个比该列当前最大值大1的值。一个表中最多只能有一个列是AUTO_INCREMENT的。

对于任何想要使用AUTO_INCREMENT的列,应该定义为NOT NULL,并定义为UNIQUE。

浮点类型

对于小数的表示,MySQL分为浮点数和定点数两种。浮点数包括float(单精度)和double(双精度),而定点数只有decimal一种。定点数在MySQL内部以字符串形式存放,比浮点数更精确,适合用来表示货币等精度高的数据。

浮点数和定点数都可以用类型名称后加"(M,D)"的方式来进行表示,"(M,D)"表示该值一共显示M位,小数有D位。MySQL保存浮点值时对超出位采用的是四舍五入的方式。因此如果在float(5,3)中插入123.006,则保存的值为123.01。float和double在不指定精度时,默认按照实际硬件和操作系统来决定;而decimal不指定时,默认整数位为10,小数位为0。

示例:

--创建表tf,分别将id1,id2,id3字段设置为float(5,2),double(5,2),decimal(5,2)
mysql> create table tf( id1 float(5,2),id2 double(5,2),id3 decimal(5,2));

--向表中三个字段分别插入数据1.23
mysql> insert into tf values(1.23,1.23,1.23);

--向表中分别插入数据1234.005
mysql> insert into tf values(1234.005,1234.005,1234.005);

--向表中分别插入数据123.005
mysql> insert into tf values(123.005,123.005,123.005);

--向表中分别插入数据123.006,123.006,123.004
mysql> insert into tf values(123.006,123.006,123.004);

--去掉表tf字段的精度,并重新插入1.23
mysql> alter table tf modify id1 float;
mysql> alter table tf modify id2 double;
mysql> alter table tf modify id3 decimal;
mysql> insert into tf values(1.23,1.23,1.23);
mysql> desc tf;

--向表中分别插入1.234567123321,1.234567123321123321,1.23234233
mysql> insert into tf values(1.234567123321,1.234567123321123321,1.23234233);

位类型

对于BIT类型,用于存放位字段值,BIT(M)可以用来存放多位二进制数,M范围从1~64,如果不写,默认为1位。而直接使用SELECT命令不会看到查询结果,需使用bin()(显示为二进制)函数或者hex()(显示为16进制)函数进行读取。

示例:

--创建表tb,定义字段id1为bit(1),id2字段为bit
mysql> create table tb(id1 bit(1),id2 bit);

--向tb中插入1,1
mysql> insert into tb values(1,1);
mysql> select * from tb;
mysql> select bin(id1),hex(id2) from tb;

数据插入bit两类型字段时,首先转换为二进制,如果位数允许,则成功插入;如果位数超出定义的位数,则插入失败。

时间类型

MySQL中由多种数据类型可以用于日期和时间的表示,下表是MySQL5.0中所有支持的日期和时间类型。

日期和时间类型 字节 最小值 最大值
DATE 4 1000-01-01 9999-12-31
DATETIME 8 1000-01-01 00:00:00 9999-12-31 23:59:59
TIMESTAMP 4 19700101080001 2038年某个时刻
TIME 3 -838:59:59 838:59:59
YEAR 1 1901 2155

每种时间类型都有一个有效范围,如果超出这个范围,在默认的SQLMode下,系统会进行错误提示,并将以零值来进行存储。

数据类型

零值表示DATE0000-00-00DATETIME0000-00-00 00:00:00TIMESTAMP00000000000000TIME00:00:00YEAR0000

--创建表tdt
mysql> create table tdt(dt date, dttm datetime, tms timestamp,tm time,yr year);

--使用now()函数向表中插入当前时间
mysql> insert into tdt values(now(),now(),now(),now(),now() );

--向tms中插入NULL,MySQL会自动赋值系统时间
mysql> insert into tdt(tms) values(null);

MySQL只会给表中第一个TIMESTAMP字段赋值系统时间,如果有其他的,则赋值为0值。

--修改表tdt,增加TIMESTAMP类型的tms1列,并给tms,tms1赋值null
mysql> alter table tdt add tms1 timestamp;
mysql> desc tdt;
mysql> insert into tdt(tms,tms1) values(null,null);

TIMESTAMP有一个重要特点,就是和失去相关。当插入提起时,会先转换为本地时区后存放;而从数据库取出时,需要将日期转换为本地时区后显示。

--创建表tdt1,包含字段tms,dt
mysql> create table tdt1(tms timestamp,dt datetime);

--查看当前时区,并向表tdt1中插入系统时间
mysql> show variables like 'time_zone';
mysql> insert into tdt1 values(now(),now());

可以发现,时区的值为SYSTEM,这个值默认是和主机的时区一致的,因为处在中国,这里实际是东八区(+8:00)。

--修改时区为东九区,再次查看tdt1中的时间
mysql> set time_zone='+9:00';

字符串类型

MySQL中提供了多种对字符串数据的存储类型,不同版本有所差异。以5.0为例,MySQL包括了CHARVARCHARBINARYVARBINARYBLOBTEXTENUMSET等多种。

数据类型 描述即存储
CHAR(M) M为0~255之间的整数
VARCHAR(M) M为0~65535之间的整数,值的长度+1个字节
TINYBLOB 允许长度0~255字节,值的长度+1个字节
BLOB 允许长度0~65535字节,值的长度+2个字节
MEDIUMBLOB 允许长度0~167772150字节,值的长度+3个字节
LONGBLOB 允许长度0~4294967295字节,值的长度+4个字节
TINYTEXT 允许长度0~255字节,值的长度+1个字节
TEXT 允许长度0~65535字节,值的长度+2个字节
MEDIUMTEXT 允许长度0~167772150字节,值的长度+3个字节
LONGTEXT 允许长度0~4294967295字节,值的长度+4个字节
VARBINARY(M) 允许长度0~M个字节的变长字节字符串,值的长度+1个字节
BINARY(M) 允许长度0~M个字节的定长字节字符串

方法

CHAR和VARCHAR

两者很类似,都用来保存MySQL中较短的字符串。二者主要区别在于存储方式的不同:CHAR列的长度固定为创建表时声明的长度;而VARCHAR列中的值为可变长字符串。在检索时,CHAR会删除尾部的空格,而VARCHAR不会。

--创建表tc,包含两个字段ch(char(6))和vc(varchar(6))
mysql> create table tc (ch char(6),vc varchar(6));
--向ch和vc字段插入'abc   '
mysql> insert into tc values('abc   ','abc   ');
--查询字段长度
mysql> select length(ch),length(vc) from tc;

BINARY和VARBINARY

类似于CHAR和VARCHAR,不同的是它们存储的是二进制的字符串。

--创建表tbc,包含字段bc(binary(6))、vbc(varbinary(6))
mysql> create table tbc (bc binary(6),vbc varbinary(6));
--向表中插入数据('a  ','a  ')
mysql> insert into tbc values('a  ','a  ');
--查看字段值长度
mysql> select length(bc),length(vbc) from tbc;

当保存BINARY值时,MySQL通过在值的最后填充0x00(零字节)以达到指定的字段定义长度。

--通过hex()函数查看tbc中数据的保存
mysql> select length(bc),length(vbc) from tbc;

ENUM类型

枚举类型,它的值范围需要在创建表时通过枚举方式显示指定,对1255个成员的枚举,需要1个字节存储;对于25665535个成员,需要2个字节存储。最多允许有65535个成员。

--创建表te,包含字段f1(enum('a','b','c'))
mysql> create table te(f1 enum('a','b','c'));
--向表中插入几条记录
mysql> insert into te values('a'),('B'),('3'),(null);

ENUM是忽略大小写的。还支持使用下标(从1开始,下标越界时报错)的方式插入数据。特殊值'0'表示一个空值。

SET类型

SET和ENUM非常类似,也是一个字符串对象,里面可以包含0~64个成员。根据成员个数不同,存储也有所不同。

1~8个成员的集合,占1个字节

9~16个成员的集合,占2个字节

17~24个成员的集合,占3个字节

25~32个成员的集合,占4个字节

32~64个成员的集合,占8个字节

而且,SET类型一次可以选择多个成员。

--创建表ts,包含字段f1(set())
mysql> create table ts (f1 set('a','b','c','d'));
mysql> insert into ts values('a,b'),('a,d'),('b,c,d');

--向表中插入数据('a,b,a,c,d,d')
mysql> insert into ts values('a,b,a,c,d,d');

SET类型可以从允许值集合中选择任意个元素进行组合,所以对于输入的值只要在允许值的组合范围内,都可以正确的记录到SET类型的列中。对于超出允许范围的值,报错。而有重复成员的集合,将自动去重。

到此这篇关于MySQL 5.7常见数据类型的文章就介绍到这了,更多相关MySQL数据类型内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • mysql数据类型和字段属性原理与用法详解

    本文实例讲述了mysql数据类型和字段属性.分享给大家供大家参考,具体如下: 本文内容: 数据类型 数值类型 整数型 浮点型 定点型 日期时间类型 字符串类型 补充: 显示宽度与zerofll 记录长度 字段属性 空\不为空值:NULL.NOT NULL 主键:primary key 唯一键:unique key 自增长:auto_increment 默认值:default 字段描述:comment 补充: 复合键 首发日期:2018-04-08 数据类型: mysql的数据类型就是存储数据的类

  • 三种常用的MySQL 数据类型

    MySQL中定义数据字段的类型对你数据库的优化是非常重要的. MySQL支持多种类型,大致可以分为三类:数值.日期/时间和字符串(字符)类型. 数值类型 MySQL支持所有标准SQL数值数据类型. 这些类型包括严格数值数据类型(INTEGER.SMALLINT.DECIMAL和NUMERIC),以及近似数值数据类型(FLOAT.REAL和DOUBLE PRECISION). 关键字INT是INTEGER的同义词,关键字DEC是DECIMAL的同义词. BIT数据类型保存位字段值,并且支持MyIS

  • 将pymysql获取到的数据类型是tuple转化为pandas方式

    我就废话不多说了,大家还是直接看代码吧! #执行结果转化为dataframe df = pd.DataFrame(list(result)) 补充知识:python pymysql注意事项 cursor.execute 与 cursor.executemany有许多不同的地方 1. execute 中字段的值是字符串形式时必须加引号,但是executemany只需要使用占位符%s,pymysql利用给的参数list自动会加上引号 2.execute返回结果都是数字,但是executemany返回

  • 基于PostgreSQL和mysql数据类型对比兼容

    1.数值类型 整数: mysql中的整数类型和pg相比,两者有以下区别: mysql:mysql中支持int 1,2,3,4,8 字节,同时支持有符号,无符号.并且mysql中支持在数值列中指定zerofill,用来将存储的数值通过填充0的方式达到指定数据类型的长度(mysql8开始不建议使用ZEROFILL属性,并且在将来的MySQL版本中将不再支持该属性). pg:pg支持 int 2,4,8 字节,且数值都是有符号的. mysql整数类型: pg整数类型: 那么对于mysql中的1,3字节

  • mysql8.0.19基础数据类型详解

    mysql基础数据类型 mysql常用数据类型概览 ![1036857-20170801181433755-146301178](D:\笔记\mysql\复习\1036857-20170801181433755-146301178.png)1. 数字: 整型:tinyinit int bigint 小数: float :在位数比较短的情况下不精准 double :在位数比较长的情况下不精准 0.000001230123123123 存成:0.000001230000 decimal:(如果用小数

  • MySQL 5.7常见数据类型

    --<深入浅出MySQL(第二版)>笔记 数值类型 整数类型 字节 最小值 最大值 TINYINT 1 有符号 -128:无符号 0 有符号 127:无符号 255 SMALLINT 2 有符号 -2^16:无符号 0 有符号 2^16-1:无符号 2^17-1 MEDIUMINT 3 有符号 -2^24:无符号 0 有符号 2^24-1:无符号 2^25-1 INT\INTEGER 4 有符号 -2^32:无符号 0 有符号 2^32-1:无符号 2^33-1 BIGINT 8 有符号 -2

  • PHP+MySQL存储数据常见中文乱码问题小结

    本文实例总结了PHP+MySQL存储数据常见中文乱码问题.分享给大家供大家参考,具体如下: PHP+MySQL出现中文乱码的常见原因: 1. MYSQL数据库的编码是utf8,与PHP网页的编码格式不一致,就会造成MYSQL中的中文乱码. 2. 使用MYSQL中创建表.或者选择字段时设置的类型不是utf8,而网页编码不是utf8,也可能造成MYSQL中文乱码. 3. PHP页面的字符集与数据库的编码不一致. 4. PHP连接MYSQL数据库,操作是设定的语句指定的编码和页面编码,PHP页面编码不

  • MySQL操作之JSON数据类型操作详解

    上一篇文章我们介绍了mysql数据存储过程参数实例详解,今天我们看看MySQL操作之JSON数据类型的相关内容. 概述 mysql自5.7.8版本开始,就支持了json结构的数据存储和查询,这表明了mysql也在不断的学习和增加nosql数据库的有点.但mysql毕竟是关系型数据库,在处理json这种非结构化的数据时,还是比较别扭的. 创建一个JSON字段的表 首先先创建一个表,这个表包含一个json格式的字段: CREATE TABLE table_name ( id INT NOT NULL

  • MySQL查询条件常见用法详解

    本文实例讲述了MySQL查询条件常见用法.分享给大家供大家参考,具体如下: 条件 使用where子句对表中的数据筛选,结果为true的行会出现在结果集中 语法如下: select * from 表名 where 条件; 例: select * from students where id=1; where后面支持多种运算符,进行条件的处理 比较运算符 逻辑运算符 模糊查询 范围查询 空判断 比较运算符 等于: = 大于: > 大于等于: >= 小于: < 小于等于: <= 不等于:

  • MySQL流程函数常见用法实例分析

    本文实例讲述了MySQL流程函数常见用法.分享给大家供大家参考,具体如下: 流程函数是MySQL相对常用的一类函数, 用户可以使用这类函数在一个SQL语句中实现条件选择, 这样能够提高效率. 下面列出了MySQL跟条件有关的流程函数 函数 功能 IF(expr1,expr2,expr3) 如果expr1是真, 返回expr2, 否则返回expr3 IFNULL(expr1,expr2) 如果expr1不是NULL,返回expr1,否则返回expr2 CASE WHEN [value1] THEN

  • mysql中各种常见join连表查询实例总结

    本文实例讲述了mysql中各种常见join连表查询.分享给大家供大家参考,具体如下: 通常我们需要连接多个表查询数据,以获取想要的结果. 一.连接可以分为三类: (1) 内连接:join,inner join (2) 外连接:left join,left outer join,right join,right outer join,union,union all (3) 交叉连接:cross join 二.准备需要演示的表: CREATE TABLE `a` ( `id` int(11) uns

  • MySQL必备的常见知识点汇总整理

    本文实例总结了MySQL必备的常见知识点.分享给大家供大家参考,具体如下: 最近在整理 sql 的时候发现一份优秀的笔记,是原作者学习 sql 所做的笔记,分享这份总结给大家,对大家对 sql 的可以来一次全方位的检漏和排查,感谢原作者 hjzCy 的付出,原文链接放在文章最下方,如果出现错误,希望大家共同指出! 登录和退出 MySQL 服务器 # 登录MySQL $ mysql -u root -p12345612 # 退出MySQL数据库服务器 exit; 基本语法 -- 显示所有数据库 s

  • Redis安装启动及常见数据类型

    Redis 简介 Redis 是我们在互联网应用中使用最广泛的一个 NoSQL 数据库,基于 C 开发的键值对存储数据库. Redis 这个名字是 Remote Dictionary Service 字母缩写. 很多人想到 Redis,就想到缓存.但实际上 Redis 除了缓存之外,还有许多更加丰富的使用场景.比如分布式锁,限流. Redis 特点 支持数据持久化 支持多种不同的数据结构类型之间的映射 支持主从模式的数据备份 自带了发布订阅系统 定时器.计数器 redis的安装 四种方式获取一个

  • MySQL中JSON字段数据类型详解

    目录 前言 创建JSON值 搜索JSON类型数据 在 JSON 和非 JSON 值之间转换 JSON 值的汇总 总结 前言 JSON 类型是从 MySQL 5.7 版本开始支持的功能,MySQL 支持由RFC 7159定义的本机JSON数据类型,该类型可有效访问 JSON(JavaScript 对象 table 示法)文档中的数据.与将 JSON 格式的字符串存储在字符串列中相比,JSON数据类型具有以下优点: 自动验证存储在JSON列中的 JSON 文档.无效的文档会产生错误. 优化的存储格式

  • MySQL所支持的数据类型与表字段约束类型的学习教程

    MySQL 数据(字段)类型 在创建表的时候,要明确定义字段对应的数据类型.MySQL 主要的数据类型分为数值类型.字符串(文本)类型.时间日期类型和其他类型几类. 数值类型 数值类型说明: 补充说明 在 int(integer) 系列中,只能存储整型值,且可以在后面用括号指定显示的尺寸(M),如果不指定则会默认分配.如果实际值的显示宽度大于设定值,将会显示实际值而不会截断以适应显示尺寸.如 smallint(3) 中的 3 即为显示尺寸,即显示三位的数值(不包括 - 号) int 类型可以指定

随机推荐