【MySQL】详解MySQL数据类型

一、数据类型

各类型的数值范围:


在MySQL中,整型可以指定是有符号的和无符号的,默认是有符号的。 可以通过UNSIGNED来说明某个字段是无符号的。对于int类型可能存放不下的数据,尽量不使用unsigned,unsigned int 同样可能存放不下,与其如此,还不如设计时,将int类型提升为bigint类型。

1.1、bit类型

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

bit字段在显示时,是按照ASCII 码对应的值显示

mysql> insert into tt4 values ( 65 , 65 );
mysql> select * from tt4;
+------+------+
| id | a |
+------+------+
| 10 | |
| 65 | A |
+------+------+

如果我们有这样的值,只存放0****或1,这时可以定义bit(1)。这样可以节省空间。比如说我们要区分男女的时候。

1.2、float

float[(m, d)] [unsigned] : M指定显示长度,d指定小数位数,占用空间4个字节。

sql 复制代码
insert into tt6 values(101, -99.991); #多的这一点被拿掉了

float(4,2)表示的范围是**-99.99 ~ 99.99,** MySQL在保存值时会进行四舍五入**。 如果定义的是float(4,2) unsigned, 这时因为把它指定为无符号的数,范围是 0 ~ 99.99。如果我们插入的是-99.991,那么实际上数据库中插入的是-99.99,如果我们插入的是99.996,那么数据库会不让我们插入,因为99.996被当成了100,超过了数值范围。**

1.3、decimal

decimal(m, d) [unsigned] : 定点数m指定长度,d表示小数点的位数。

sql 复制代码
create table tt8 ( id int, salary float(10,8), salary2 decimal(10,8));
insert into tt8 values(100,23.12345612, 23.12345612);

decimal(5,2) 表示的范围是 -999.99 ~ 999.99。decimal(5,2) unsigned****表示的范围 0 ~ 999.99。decimal和float很像,但是有区别。float和decimal表示的精度不一样。float表示的精度大约是7位,decimal整数最大位数m为65。支持小数最大位数d是30。如果d被省略,默认为0.如果m被省略,默认是10。 如果希望小数的精度高,推荐使用decimal

1.4、char

char(L): 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255。

char(2) 表示可以存放两个字符,可以是字母或汉字,但是不能超过****2个。 在MySQL中,字符就真的是字符,字母或汉字都认为是字符

1.5、varchar

varchar(L): 可变长度字符串,L表示字符长度,最大长度65535个字节。
varchar长度可以指定为 0到65535之间的值,但是 有1 - 3 个字节用于记录数据大小,所以说有效字节数最多是65532 。当我们的表的编码是utf8时,varchar(n)的参数n最大值是65532/3=21844[因为utf中,一个字符占用3个字节,如果编码是gbk,varchar(n)的参数n最大是65532/2=32766(因为gbk中,一个字符占用2字节)。
char和varchar类型的区别是char是你指定了多少字符就给你直接开辟多长字符的空间,而varchar是你指定了最多可以开辟多少个字节,但是实际开辟的空间根据实际情况而定,用多少,开辟多少。定长的磁盘空间比较浪费,但是效率高。变长的磁盘空间比较节省,但是效率低。

1.6、日期和时间类型

  • date :日期 'yyyy-mm-dd' ,占用三字节。
  • datetime 时间日期格式 'yyyy-mm-dd HH:ii:ss' 表示范围从 1000 到 9999 ,占用八字节。
  • timestamp :时间戳,从1970年开始的 yyyy-mm-dd HH:ii:ss 格式和 datetime 完全一致,占用四字节。
sql 复制代码
create table birthday (t1 date, t2 datetime, t3 timestamp);
insert into birthday(t1,t2) values('1997-7-1','2008-8-8 12:1:1');
//添加数据时,时间戳自动补上当前时间。

1.7、enumset

enum:枚举,"单选"类型; enum('选项1','选项2','选项3',...);
该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;而且出于效率考虑,这些值实际存储的是"数字",因为这些选项的每个选项值依次对应如下数字:1,2,3,....最多65535个;当我们添加枚举值时,也可以添加对应的数字编号。

set:集合,"多选"类型; set('选项值1','选项值2','选项值3', ...);

该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是"数字**",因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,.... 最多64个。**

sql 复制代码
mysql> create table votes(
-> username varchar(30),
-> hobby set('登山','游泳','篮球','武术'), --注意:使用数字标识每个爱好的时候,想想Linux权限,采用比
特位位置来个set中的爱好对应起来
-> gender enum('男','女')); --注意:使用数字标识的时候,就是正常的数组下标

插入数据:

sql 复制代码
insert into votes values('雷锋', '登山,武术', '男');
insert into votes values('Juse','登山,武术',2);

若想查找所有喜欢登山的人,可以采用集合查询,使用find_ in_ set函数。
find_in_set(sub,str_list) :如果 sub 在 str_list 中,则返回下标;如果不在,返回0; str_list 用逗号分隔的字符串。

查询爱好登山的人:

sql 复制代码
select * from votes where find_in_set('登山', hobby);
相关推荐
QX_hao3 小时前
【Go】--map和struct数据类型
开发语言·后端·golang
MC丶科3 小时前
【SpringBoot 快速上手实战系列】5 分钟用 Spring Boot 搭建一个用户管理系统(含前后端分离)!新手也能一次跑通!
java·vue.js·spring boot·后端
G探险者4 小时前
为何一个系统上线要经过N轮测试?带你看懂企业级发布体系
后端
TDengine (老段)5 小时前
TDengine 数学函数 DEGRESS 用户手册
大数据·数据库·sql·物联网·时序数据库·iot·tdengine
TDengine (老段)5 小时前
TDengine 数学函数 GREATEST 用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
@yanyu6665 小时前
idea中配置tomcat
java·mysql·tomcat
安当加密5 小时前
云原生时代的数据库字段加密:在微服务与 Kubernetes 中实现合规与敏捷的统一
数据库·微服务·云原生
lang201509285 小时前
Spring Boot 入门:5分钟搭建Hello World
java·spring boot·后端
爱喝白开水a5 小时前
LangChain 基础系列之 Prompt 工程详解:从设计原理到实战模板_langchain prompt
开发语言·数据库·人工智能·python·langchain·prompt·知识图谱