MySQL 5.7常见数据类型

这篇文章主要介绍了MySQL 5.7数据类型详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

Posted in MySQL onJuly 15, 2021

——《深入浅出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;

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

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

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

MySQL 5.7常见数据类型

所有的整数类型都有一个可选属性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));

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

--去掉表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;

MySQL 5.7常见数据类型

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

位类型

对于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);

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

时间类型

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);

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

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);

MySQL 5.7常见数据类型

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

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

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

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

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

MySQL 5.7常见数据类型

字符串类型

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;

MySQL 5.7常见数据类型

MySQL 5.7常见数据类型

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;

MySQL 5.7常见数据类型

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

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

MySQL 5.7常见数据类型

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);

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

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');

MySQL 5.7常见数据类型

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

MySQL 5.7常见数据类型

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

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

MySQL 相关文章推荐
解读MySQL的客户端和服务端协议
May 10 MySQL
MySQL中distinct与group by之间的性能进行比较
May 26 MySQL
解决mysql问题:由于找不到MSVCR120.dll,无法继续执行代码
Jun 26 MySQL
SQL之各种join小结详细讲解
Aug 04 MySQL
MySQL外键约束(FOREIGN KEY)案例讲解
Aug 23 MySQL
面试被问select......for update会锁表还是锁行
Nov 11 MySQL
MySQL高级进阶sql语句总结大全
Mar 16 MySQL
MySQL优化常用的19种有效方法(推荐!)
Mar 17 MySQL
Pycharm远程调试和MySQL数据库授权问题
Mar 18 MySQL
mysql 获取时间方式
Mar 20 MySQL
MySQL中优化SQL语句的方法(show status、explain分析服务器状态信息)
Apr 09 MySQL
CentOS MySql8 远程连接实战
Apr 19 MySQL
mysq启动失败问题及场景分析
解决mysql的int型主键自增问题
QT连接MYSQL数据库的详细步骤
Jul 07 #MySQL
mysql备份策略的实现(全量备份+增量备份)
mysql定时自动备份数据库的方法步骤
通过shell脚本对mysql的增删改查及my.cnf的配置
Jul 07 #MySQL
MySQL一些常用高级SQL语句
You might like
ThinkPHP3.0略缩图不能保存到子目录的解决方法
2012/09/30 PHP
PHP preg_match实现正则表达式匹配功能【输出是否匹配及匹配值】
2017/07/19 PHP
PHP实现打包下载文件的方法示例
2017/10/07 PHP
《JavaScript高级编程》学习笔记之object和array引用类型
2015/11/01 Javascript
Bootstrap实现默认导航栏效果
2020/09/21 Javascript
通过Ajax使用FormData对象无刷新上传文件方法
2016/12/08 Javascript
JavaScript、C# URL编码、解码总结
2017/01/21 Javascript
vue jsx 使用指南及vue.js 使用jsx语法的方法
2017/11/11 Javascript
vue + element-ui实现简洁的导入导出功能
2017/12/22 Javascript
原生JS实现前端本地文件上传
2018/09/08 Javascript
微信小程序的线程架构【推荐】
2019/05/14 Javascript
jQuery zTree插件快速实现目录树
2019/08/16 jQuery
一步一步实现Vue的响应式(对象观测)
2019/09/02 Javascript
vue使用lodop打印控件实现浏览器兼容打印的方法
2021/02/07 Vue.js
[01:07:22]2014 DOTA2华西杯精英邀请赛 5 24 DK VS VG加赛
2014/05/26 DOTA
[01:10:58]KG vs TNC 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
详细讲解用Python发送SMTP邮件的教程
2015/04/29 Python
python协程用法实例分析
2015/06/04 Python
python3.4.3下逐行读入txt文本并去重的方法
2018/04/29 Python
解决DataFrame排序sort的问题
2018/06/07 Python
python分批定量读取文件内容,输出到不同文件中的方法
2018/12/08 Python
python实现烟花小程序
2019/01/30 Python
Django中使用CORS实现跨域请求过程解析
2019/08/05 Python
python实现while循环打印星星的四种形状
2019/11/23 Python
pymysql 插入数据 转义处理方式
2020/03/02 Python
Python和Bash结合在一起的方法
2020/11/13 Python
关于canvas绘制模糊问题的解决方法
2019/09/24 HTML / CSS
美国经典刺绣和字母儿童服装特卖:Smocked Auctions
2018/07/16 全球购物
渗透攻击的测试步骤
2014/06/07 面试题
预备党员入党自我评价范文
2014/03/10 职场文书
文案策划求职信
2014/04/14 职场文书
大型演出策划方案
2014/05/28 职场文书
普通党员自我剖析材料
2014/10/07 职场文书
开学第一天的感想
2015/08/10 职场文书
小学语文教师竞聘演讲稿范文
2019/08/09 职场文书
Python爬虫基础讲解之请求
2021/05/13 Python