【MySQL】数据类型

目录

 

1. 数据类型分类

2. 数值类型

2.1 tinyint类型

2.2 bit类型

2.3 小数类型

2.3.1 float

2.3.2 decimal

4.3 字符串类型

4.3.1 char

4.3.2 varchar

4.3.3 char和varchar比较

4.4 日期和时间类型

4.5 enum和set


MySQL

1. 数据类型分类

【MySQL】数据类型_第1张图片

2. 数值类型

【MySQL】数据类型_第2张图片

 2.1 tinyint类型

数值越界测试:
【MySQL】数据类型_第3张图片
说明:
  • MySQL中,整型可以指定是有符号的和无符号的,默认是有符号的;
  • 可以通过UNSIGNED来说明某个字段是无符号的;

无符号案例:

【MySQL】数据类型_第4张图片

其他的数值类型感兴趣的可以自己下去试着玩下;

注意:
尽量不使用 unsigned ,对于 int 类型可能存放不下的数据, int unsigned 同样可能存放不下,与
其如此,还不如设计时,将int 类型提升为 bigint 类型。

2.2 bit类型

基本语法:
bit[(M)] 

// 位字段类型。M表示每个值的位数,范围从1到64。如果M被忽略,默认为1。

【MySQL】数据类型_第5张图片

bit 使用的注意事项:
  • bit字段在显示时,是按照ASCII码对应的值显示;

【MySQL】数据类型_第6张图片

上述插入语句最后进行查询时没有显示,是因为ASCII码分为控制字符和打印字符,只有打印

字符最后 select 语句进行查询时,才能显示;

  • 如果我们有这样的值,只存放 0 1 ,这时可以定义 bit(1) 。这样可以节省空间;
【MySQL】数据类型_第7张图片

2.3 小数类型

2.3.1 float

语法:
float[(m, d)] [unsigned]

// M指定显示长度,d指定小数位数,占用空间4个字节
案例:
小数: float(4,2) 表示的范围是 -99.99 ~ 99.99 MySQL 在保存值时会进行四舍五入。
【MySQL】数据类型_第8张图片
问题:
当我们的  float(4,2)  如果是一个有符号的,则表示范围是 -99.99 ~ 99.99
当我们的  float(6,2)  如果是一个有符号的,则表示范围是 -9999.99 ~ 9999.99
案例:
如果定义的是  float(4,2) unsigned 这时,因为把它指定为无符号的数,范围是 0 ~ 99.99;
【MySQL】数据类型_第9张图片

2.3.2 decimal

语法:
decimal(m, d) [unsigned] 

// 定点数m指定长度,d表示小数点的位数
  • decimal(5,2) 表示的范围是 -999.99 ~ 999.99
  • decimal(5,2) unsigned 表示的范围 0 ~ 999.99
decimal 和 float 很像,但是有区别:float 和 decimal 表示的精度不一样:
【MySQL】数据类型_第10张图片
说明:
float  表示的精度大约是 7 位;
decimal  整数最大位数 m 65, 支持小数最大位数 d 30;
如果 d 被省略,默认为 0, 如果 m 被省略,默认是 10
建议:如果希望小数的精度高,推荐使用decimal。

4.3 字符串类型

4.3.1 char

语法:
char(L)

// 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255
案例( char ):
【MySQL】数据类型_第11张图片
说明:
char(2) 表示可以存放两个字符,可以是字母或汉字,但是不能超过 2 个, 最多只能是 255 ;

4.3.2 varchar

语法:
varchar(L)

// 可变长度字符串,L表示字符长度,最大长度65535个字节
案例:
【MySQL】数据类型_第12张图片
说明:
关于 varchar(len),len 到底是多大,这个 len 值,和表的编码密切相关:
  • varchar长度可以指定为065535之间的值,但是有1 - 3 个字节用于记录数据大小,所以说有效字节数是65532;
  • 当我们的表的编码是 utf8 时,varchar(n)的参数n最大值是 65532/3=21844 [因为utf中,一个字符占用3个字],如果编码是gbkvarchar(n)的参数n最大是 65532/2=32766(因为gbk中,一个字符占用2字节)

不同的环境上述varchar最大字符值可能不同,我是使用的云服务器 mysql5.7版本,varchar最大字符值是21842;

【MySQL】数据类型_第13张图片

4.3.3 charvarchar比较

如何选择定长或变长字符串?
  • 如果数据确定长度都一样,就使用定长(char),比如:身份证,手机号,md5;
  • 如果数据长度有变化,就使用变长(varchar), 比如:名字,地址,但是你要保证最长的能存的进去;
  • 定长的磁盘空间比较浪费,但是效率高;
  • 变长的磁盘空间比较节省,但是效率低;
  • 定长的意义是,直接开辟好对应的空间;
  • 变长的意义是,在不超过自定义范围的情况下,用多少,开辟多少;

4.4 日期和时间类型

常用的日期有如下三个:
  •  date 日期 'yyyy-mm-dd' ,占用三字节;
  •  datetime 时间日期格式 'yyyy-mm-dd HH:ii:ss' 表示范围从 1000 9999 ,占用八字节;
  •  timestamp 时间戳,从1970年开始的 yyyy-mm-dd HH:ii:ss 格式和 datetime 完全一致,占用四字节;
案例:
【MySQL】数据类型_第14张图片
在上述中我们不必在意输入的格式,日期类型会自动调整格式;

4.5 enumset

语法:
  • enum:枚举,单选类型;
enum('选项1','选项2','选项3',...);
该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;
而且出于效率考虑,这些值实际存储的是“ 数字 ,因为这些选项的每个选项值依次对应如下
数字: 1,2,3,.... 最多 65535 个;当我们添加枚举值时,也可以添加对应的数字编号。
  • set:集合,多选类型;
set('选项值1','选项值2','选项值3', ...);
该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;
而且出于效率考虑,这些值实际存储的是“ 数字 ,因为这些选项的每个选项值依次对应如下
数字: 1,2,4,8,16,32 .... 最多 64 个。
说明:不建议在添加枚举值,集合值的时候采用数字的方式,因为不利于阅读。
案例:
有一个调查表 votes ,需要调查人的喜好;
比如(登山,游泳,篮球,武术)中去选择 [ 可以多选] ,(男,女) [ 单选 ]
【MySQL】数据类型_第15张图片
有如上数据,想查找所有喜欢游泳的人:
使用如下查询语句:
【MySQL】数据类型_第16张图片
如上不能查询出所有,爱好为游泳的人。
集合查询使用  find_ in_ set  函数:
 find_in_set(sub,str_list) :如果 sub str_list 中,则返回下标;
如果不在,返回 0
str_list 用逗号分隔的字符串。

【MySQL】数据类型_第17张图片

 查询爱好游泳的人:

【MySQL】数据类型_第18张图片

坚持打卡

你可能感兴趣的:(MySQL,mysql,数据库)