MySQL-数据类型

MySQL-数据类型

  • 数值类型
    • bit
    • tinyint
    • float
    • decimal
  • 字符串和文本类型
    • char
    • varchar
    • blob
    • text
  • 日期和时间类型
  • enum-枚举类型
  • set-集合类型

数值类型

数据类型说明
bit(M)位类型。M指定位数,默认值为1,范围1-64.
tinyint [unsigned]带符号范围:-128 - 127,无符号范围: 0 - 255
bool使用0和1表示假和真
smallint [unsigned]带符号范围:-2^15 - 2^15 - 1,无符号范围:0 - 2^16 - 1
mediumint [unsigned]带符号范围:-2^23 - 2^23 - 1,无符号范围:0 - 2^24 - 1
int [unsigned]带符号范围:-2^31 - 2^31 -1,无符号范围:0 - 2^32 - 1
double [unsigned]带符号范围: -2^63 - 2^63 - 1,无符号范围: 0 - 2^64 - 1
float[(M,D)] [unsigned]M表示显示长度,D表示小数点的位数,占用4字节
double[(M,D)] [unsigned]精度比float更高的浮点数,占用8字节
decimal[(M,D)] [unsigned]M指定长度,D表示显示小数的位数

bit

🚀bit[M]:M表示使用的比特位数,范围为1-64,bit位在显示的时候是按照Ascll码来显示的。
在这里插入图片描述

insert into t1 values(10);
insert into t1 values(11);
insert into t1 values(12);

在这里插入图片描述
可以看到插入的三个数据是显示不出来的,那是因为Ascll值为10 11 12的字符为不可显字符。插入48那么显示出来就为‘0’;
在这里插入图片描述

tinyint

🚀tinyint占用1个字节,对于有符号而言取值范围是-128 - 127。无符号的范围是0 - 255。当用户在插入数据超出其所表示的范围后会拦截我们插入。
在这里插入图片描述

insert into t2 values(127,255);
insert into t2 values(-128,255);

在这里插入图片描述

mysql会对非法数据进行拦截

insert into t2 values(128,0);

在这里插入图片描述

float

🚀float[(M,D)], M:显示长度,D:指定小数位数。

  • 例如float(4,2)所能表示的范围就是(-99.99 - 99.99),如果用unsigned修饰那么范围就是(0 - 99.99)在插入数据时会四舍五入.
insert into t3 values(-99.99);
insert into t3 values(99.99);
insert into t3 values(99.994);
insert into t3 values(-99.994);

在这里插入图片描述
同样当超出其能表示的范围后也会对我们的插入做拦截。
在这里插入图片描述

decimal

🚀decimal的用法与float一样,与float的区别是decimal比float更加精确。

insert into t4 values(14.1234567,14.1234567);

在这里插入图片描述
🚀float的精度大约是7位,对于decimal而言,支持的最大整数位数65位,支持的最大小数位数30位。decimal(M,D)默认情况下M的值为10,D的值为0。
🚀float和double是采用标准的浮点数存储形式,decimal实际存储的是字符串。

字符串和文本类型

数据类型说明
char(size)固定长度字符串,size的最大值为255
varchar(size)可变长度字符串,最大长度为65535字节
blob二进制数据
text大文本,不支持全文索引,不支持默认值

char

🚀char(size):size的最大值为255,表示char字符串最多存储255个字符(注意是字符不是字节)

在这里插入图片描述
char(2)表示能够存储两个字符。

insert into t5 values('ab');
insert into t5 values('张三');//utf8编码规则下一个中文字符占用3个字节

在这里插入图片描述

varchar

🚀varchar(size)是变长字符串,当实际字符串长度小于size时,那么占用的空间以实际varchar长度为准。注意:这里的size指的是字节

  • varchar的长度为0-65535之间的值,但是其中要占用1-3字节来记录实际varchar的长度,所以varchar的实际可用长度最大为65532字节。
  • 那么,在不同的编码规则下,varchar所能存储的字符数量也是不同的,例如在utf8编码规则下一个字符占用3字节,所以varchar可存储的最大字符数为 65532 / 3。在gbk编码规则下一个字符占用2字节,所以varchar可存储的最大字符数为65532 / 2。

varchar和char该如何选择呢?

1.当存储一些定长的数据的时候,例如身份证号,手机号,学号等等,最好使用定长字符串。
2.当存储的数据长度不定的时候,例如名字,家庭住址,商品名称等等,最好使用变长字符串。
3.定长字符串IO效率高。
4.变长字符串IO效率低。

blob

🚀例如,在持久化存储的时候,通常都要对结构化数据进行序列化,将序列化后的数据进行持久化存储,序列化的工具有很多,Json,protobuf等等,使用protobuf序列化的结果就是二进制数据,此时就可以使用blob数据类型来存储。

text

🚀当存储一些大的文本数据时,就可以使用text数据类型,text数据类型不支持全文索引,不支持默认值。

日期和时间类型

🚀常用的时间类型有以下三种:

  • date:‘yyyy-mm-dd’,表示年月日,占用3字节。
  • datatime:‘yyyy-mm-dd HH:ii:ss’,表示年月日时分秒,表示范围1000-9999,占用8字节。
  • timestamp:时间戳,从1970年至今的秒数,表示的格式与datatime一致,占用4字节。

注意: 时间戳形式的数据在插入时不用显示的插入数据,系统会自动填入此时的时间戳,并且在进行更新数据时,时间戳数据也会自动更新。

在这里插入图片描述

insert into t7(birthday,time) values('2000-01-01','2000-01-01 15:15:15');

在这里插入图片描述

update t7 set time='2020-10-01 09:00:00';

在这里插入图片描述
可以看到更新数据时,时间戳字段也会自动更新。

enum-枚举类型

🚀enum类型,多选一,在实际存储的时候只会存储众多选项中的 某一个值。而处于效率考虑,这些值实际存储时存储的是‘数字’,枚举常量中的每个值对应 1…,最大到65535个,所用插入枚举值的时候,不仅可以使用枚举值也可以使用其对应的数字。

🚀例如,在表示性别的时候,就可以使用enum类型。

create table t8 ( sex enum('男','女') );

在这里插入图片描述

insert into t8 values('男');
insert into t8 values(1);

在这里插入图片描述
可以看到,无论插入’男’还是1,结果都是一样的。

set-集合类型

🚀set类型,支持多选一,多选多,当然也可以不选填入NULL值。同样,实际集合类型存储的也是‘数字’,集合中的每个选项对应1,2,4,8…,最多64个。可以理解为每个二进制位对应一个选项。在插入时同样可以使用数字。(无论枚举还是集合,不建议使用数字的形式,不易阅读)。

例如,描述一个人爱好的时候,就可以使用集合类型,比如一个人的爱好有抽烟,喝酒,烫头。

create table t10 ( id int, hobby set('跑步','游泳','篮球','足球','排球','骑行'));

在这里插入图片描述

insert into t10 values(1,'篮球,跑步,游泳'),(2,'篮球,排球,足球'),(3,'骑行,跑步,足球,游泳'),(4,'游泳');

在这里插入图片描述
🚀查询时可以使用名称和数字都可以。
在这里插入图片描述
在这里插入图片描述

7 = 1 + 2 + 4 :表示爱好为跑步,游泳,篮球的人。

面临的问题:例如,我们想查询出爱好有篮球的人,使用hobby=‘篮球’是不对的(这个意思是爱好只有篮球的人),可以借助find_in_set(sub,list)函数来完成。如果sub在list中返回其下标(从1开始),不在就返回0。

在这里插入图片描述

select * from t10 where find_in_set('篮球',hobby);

在这里插入图片描述

🚀选出爱好有骑行或者有游泳的人。

select * from t10 where find_in_set('骑行',hobby) or find_in_set('游泳',hobby);

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/119025.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JavaScript 生成 16: 9 宽高比

这篇文章只是对 for 循环一个简单应用,没有什么知识含量。 可以跳过这篇文章。 只是我用来保存一下我的代码,保存在本地我嫌碍眼,总想把他删了。 正文部分 公式:其中 width 表示宽度,height 表示高度 16 9 w i d t…

【微服务部署】一、使用docker-compose部署Jenkins、SonarQube、PostgreSQL

一、安装 1、编写docker-compose部署Postgres、SonarQube、Jenkins的yml文件jenkins-compose.yml Postgres:作为SonarQube的数据库存储SonarQube:代码质量检查Jenkins:jenkins/jenkins:lts镜像,jenkinsci/blueocean镜像缺少node…

22.3D等距社交媒体菜单的悬停特效

效果 源码 <!doctype html> <html><head><meta charset="utf-8"><title>CSS Isometric Social Media Menu</title><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.1.…

Vue框架--理解MVVM

我们知道&#xff0c;MVVM是Model-View-ViewModel的简写。它本质上就是MVC的改进版。我们看看MVVM的模型架构&#xff0c;如下所示: 架构理解与实例

git大文件推送报错

报错信息 不多掰扯&#xff0c;直接上报错信息和截图 Delta compression using up to 8 threadsRPC failde; HTTP 413 curl 22 The requested URL returned error: 413 Request Entity Too Large从以上的报错信息不难看出推送仓库的时候&#xff0c;请求体过大&#xff0c;为…

供热管网安全运行监测,提升供热管网安全性能

城市管网是城市的“生命线”之一&#xff0c;是城市赖以生存和发展的基础&#xff0c;在城市基础设施高质量发展中发挥着重要作用。供热管网作为城市生命线中连接供热管线与热用户的桥梁&#xff0c;担负着向企业和居民用户直接供热的重要职责。随着城市热力需求的急剧增加&…

网络实验 VlAN 中 Trunk Access端口的说明及实验

网络实验 VlAN 中 Trunk Access端口的说明及实验 VlAN 虚拟局域网技术Access端口 工作原理Trunk端口 工作原理简单实验&#xff08;一&#xff09;划分不同Vlan&#xff0c;实现vlan内部通信拓朴图主机IP 配置划分Vlanping 测试 &#xff08;二&#xff09;跨交换机实现VLAN间通…

Java 复习笔记 - 学生管理系统篇

文章目录 学生管理系统一&#xff0c;需求部分需求分析初始菜单学生类添加功能删除功能修改功能查询功能 二&#xff0c;实现部分&#xff08;一&#xff09;初始化主界面&#xff08;二&#xff09;编写学生类&#xff08;三&#xff09;编写添加学生方法&#xff08;四&#…

坦克400 Hi4-T预售价28.5万元起,越野新能源好理解

8月25日&#xff0c;在以“智享蓉城&#xff0c;驭见未来”为主题的成都国际车展上&#xff0c;坦克品牌越野新能源再启新程&#xff0c;首次以全Hi4-T新能源阵容亮相展台&#xff0c;释放坦克品牌加速布局越野新能源的强烈信号。 Hi4-T架构首款落地车型坦克500 Hi4-T上市至今斩…

Kotlin判断null比较let布尔值Boolean

Kotlin判断null比较let布尔值Boolean class MyData {val count: Int? 2023val number: Int? null }fun main(args: Array<String>) {val data MyData()val year 2022if (data.count ! null) {if (data.count > year) {println("data.count ! null")}}…

Windows 操作系统下 Python 及其模块的管理

Python 是一款解释型语言&#xff0c;理论上一个.py文件可以当成一个稍微复杂一些的字符串指令集本文不涉及jupyter,VS,VScode,Pycharm 等集成开发环境&#xff0c;这不是我们这篇文章所关心的东西 这篇文章面向的是Python 的初学者 最近没有写太多长文章&#xff0c;多写几篇&…

工具分享 | PDF文档解析工具PyMuPDF

1 需求描述 最近工作需要从PDF文档中按照章节解析出对应的文本和图片(后续可能还会有表格)&#xff0c;经过调研&#xff0c;找到了一个功能强大的解析工具MuPDF&#xff0c;对应的Python包是PyMuPDF。本篇博客记录使用它来实现具体功能。 官方文档&#xff1a;https://pymupd…

WEB项目利用Eclipse打包成war包并部署在CentOS8

1、Eclipse把WEB项目打包成war包 2、Xftp上传war包到Linux中安装Tomcat的webapps目录 /usr/local/tomcat/apache-tomcat-9.0.80/webapps3、利用IP地址访问部署的项目 在CentOS中可用 ifconfig找到对应的IP地址 http://192.168.122.2:8080/CentOS-Web/index.html

CSS学习笔记02

CSS笔记02 美化网页元素 为什么要美化网页 目的&#xff1a; 有效的传递页面信息美化网页、页面漂亮、才能吸引用户突显页面的主题提高用户的体验 span标签 span标签是短语内容的通用行内容器&#xff0c;它本身并没有任何特殊语义。 通常我们使用span标签来把我们想要重…

Docker部署RustDesk Server 设置开机自启

三、Docker安装 Docker官方和国内daocloud都提供了一键安装的脚本&#xff0c;使得Docker的安装更加便捷。 官方的一键安装方式&#xff1a; curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun 国内 daocloud一键安装命令&#xff1a; curl -sSL https://…

nmap的使用

目录 nmap简介 主要作用 nmap原理 namp使用 options nmap列举远程机器开放端口 普通扫描 扫描范围端口 对几个端口探测 对所有端口进行探测 指定协议探测端口 扫描对应协议的所有端口 端口状态 nmap识别目标机器上服务的指纹 服务指纹 识别目标机器服务信息 …

el-tree组件的锚点链接

el-tree部分&#xff1a; <el-tree:default-expand-all"true":data"anchorList":props"defaultProps"node-click"handleNodeClick"/> 组件内部部分&#xff1a; <div class"header" :id"content obj.id&q…

界面控件Telerik UI for WPF——Windows 11主题精简模式提升应用体验

Telerik UI for WPF拥有超过100个控件来创建美观、高性能的桌面应用程序&#xff0c;同时还能快速构建企业级办公WPF应用程序。Telerik UI for WPF支持MVVM、触摸等&#xff0c;创建的应用程序可靠且结构良好&#xff0c;非常容易维护&#xff0c;其直观的API将无缝地集成Visua…

Qt Creator 创建 Qt 默认窗口程序

Qt 入门实战教程&#xff08;目录&#xff09; Windows Qt 5.12.10下载与安装 使用Qt Creator 本文介绍用Qt自带的集成开发工具Qt Creator创建Qt默认的窗口程序。 本文不需要你另外安装Visual Studio 2022这样的集成开发环境&#xff0c;也不需要你再在Visual Studio 2022中…

43、基于 springboot 自动配置的 spring mvc 错误处理,就是演示项目报错后,跳转到自定义的错误页面

Spring MVC 的错误处理&#xff1a;基于 SpringBoot 自动配置之后的 Spring MVC 错误处理。 就是访问方法时出错&#xff0c;然后弄个自定义的错误页面进行显示。 ★ 两种错误处理方式 方式一&#xff1a; 基于Spring Boot自动配置的错误处理方式&#xff0c;只要通过属性文件…