[MySQL]数据类型(图文详解)

news2024/9/20 10:37:51

[MySQL]数据类型

文章目录

  • [MySQL]数据类型
    • 1. 数据类型分类
    • 2. 数值类型
      • 2.1 bit类型
      • 2.2 tinyint类型
      • 2.3 float类型
      • 2.4 decimal类型
      • 2.5 char类型
      • 2.6 varchar类型
      • 2.7 日期和时间类型
      • 2.8 enum和set类型

1. 数据类型分类

image-20230706152255359

2. 数值类型

说明:

  • 数值类型在定义时不加unsigned限定的,都会被创建为有符号数。
  • 只能将数值类型范围内的数据插入表中。
  • 在C/C++语言中,数据类型不匹配时,编译器可能会进行截断、隐式类型转化等方式将不同类型的数据相互赋值,在MySQL中这是不被允许的,在MySQL中数值类型是一种约束,限制程序员插入更正确的数据,这样使得数据库中的数据更加可信。

2.1 bit类型

语法:

bit [M]; #M默认为1,最大为64
  • bit是以比特位数定义的类型。
  • 不指定位数时默认为1位,最大为64。
  • 数据范围由位数决定。
  • 在表中以ASCII码的形式显示。

bit类型示例:

image-20230706162301500

image-20230706162733982

2.2 tinyint类型

tinyint、smallint、int、bigint在使用上相同,仅仅是数据表示的范围不同。

语法:

tinyint [unsigned];

tinyint类型使用示例:

image-20230706154821911

2.3 float类型

double类型的使用于float类型相同,只是精度不同,所占字节数不同。

语法:

float[(m, d)] [unsigned] #M指定显示长度,d指定小数位数,占用空间4个字节
  • MySQL保存值时会四舍五入,数据能否存入取决于四舍五入后数据是否在数据范围内。
  • 显示长度 = 整数部分位数 + 小数部分位数(定值)。
  • 显示长度小于等于M。
  • 无符号类型相比于相同显示长度、小数位数的float类型范围减半(除去负数部分)。
  • float表示的精度大约是7位。

float类型示例:

案例: 小数:float(4,2)表示的范围是-99.99 ~ 99.99。

image-20230706171847273

image-20230706172141177

由于浮点类型的数据的是以二进制形式存储的,因此无可避免的会有精度损失,并且值得注意的是,整数部分也可能有精度损失。

2.4 decimal类型

语法:

decimal(m, d) [unsigned] #定点数m指定长度,d表示小数点的位数
  • 用法与float类型相同。
  • 精度比float类型更高。

decimal类型示例:

image-20230706193340620

image-20230706193731777

  • decimal整数最大位数m为65。支持小数最大位数d是30。如果d被省略,默认为0.如果m被省略, 默认是10(不同版本MySQL可能有所不同)。

如果想要更高精度的小数,使用decimal更能满足需求。

2.5 char类型

语法:

char(L)   #固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255
  • 能存储的字符长度固定,最大为255字符
  • MySQL中的字符指的是任意字符,比如一个汉字和一个字母都是一个字符。

char类型示例:

image-20230706195608376

2.6 varchar类型

语法:

varchar(L)  #可变长度字符串,L表示字符长度,最大长度65535个字节
  • 用法上与char相同。
  • 不同于char是给定空间,varchar是需要多少空间给多少空间。
  • 最大长度为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字节)。

varchar类型示例(一下为utf8编码):

image-20230706204236931

image-20230706204644826

image-20230706205021428

由于MySQL中表的一行最多只能存储65535个字节,因此在属性列中增加属性,varchar能在一行中能使用的空间就变小了。

如何选择定长字符和变长字符?

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

2.7 日期和时间类型

date  	 	#日期 'yyyy-mm-dd' ,占用三字节
datetime 	#时间日期格式 'yyyy-mm-dd HH:ii:ss' 表示范围从 1000 到 9999 ,占用八字节
timestamp	#时间戳,从1970年开始的 yyyy-mm-dd HH:ii:ss 格式和 datetime 完全一致,占用四字节
  • timestamp所在的记录(行)有插入、修改操作,timestamp都自动更新。

日期和时间类型示例:

image-20230706211948331

image-20230706211850450

2.8 enum和set类型

enum语法:

enum('选项1','选项2','选项3',...);

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

set语法:

set('选项值1','选项值2','选项值3', ...);

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

说明:不建议在添加枚举值,集合值的时候采用数字的方式,因为不利于阅读。

enum和set类型示例:

image-20230707152355111

image-20230707152506656

image-20230707152926695

image-20230707153003580

image-20230707153235054

image-20230707153604171

image-20230707153657304

image-20230707154006784

enum和set类型查找

image-20230707161152645

image-20230707161414466

image-20230707161511919

image-20230707161722198

image-20230707161855689

为了查询含有代码的记录,而不是只有代码的记录,需要借助以下函数:

find_in_set(sub,str_list)  #如果 sub 在 str_list 中,则返回下标;如果不在,返回0;str_list 用逗号分隔的字符串。
  • 返回0代表sub不在str_list中,返回非0即使sub在str_list中的下标。
  • sub中只有一个字符才有效,如果要查询多个字符需要逻辑与(and)关键字。

find_in_set示例:

image-20230707162359851

image-20230707162518066

用find_in_set解决set查询问题:

image-20230707162825004

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【雕爷学编程】Arduino动手做(154)---AFMotor电机扩展板模块

37款传感器与执行器的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止这37种的。鉴于本人手头积累了一些传感器和执行器模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的&am…

备忘录模式的学习与使用

1、备忘录模式的学习 当您需要在不破坏封装性的前提下保存和恢复对象的状态时,备忘录模式是一种有用的设计模式。备忘录模式允许您将对象的状态保存到备忘录对象中,并在需要时从备忘录中恢复状态。这种模式分离了状态的保存和恢复逻辑,使得对…

stm32usart+中断接收定长数据

文章目录 前言一、cubemx的配置二、代码编写1.主函数在这里插入图片描述2. it.c 总结 前言 中断接收固定的数据值。 一、cubemx的配置 开启USART1 打开NVIC中断 二、代码编写 1.主函数 #define RxBuf_SIZE_1 50 //USART1接收缓冲区大小 #define MainBuf_SIZE_1 50 //USAR…

实现会议管理功能

目录 生成原始会议数据 一、数据结构 二、添加测试数据 查询会议列表分页数据(后端) 一、业务分析 二、编写持久层代码 三、编辑业务层代码 四、编写Web层代码 查询成员列表(后端) 一、编写持久层代码 二、编写业务层…

Mybatis-plus——查询条件设置+字段映射和表名映射

查询条件设置 等匹配查询 假如要进行登录查询的话&#xff0c;需要用到如下的等匹配&#xff0c;在实际的登录中应该做md5加密&#xff0c;从查询条件取出密码。 //条件查询LambdaQueryWrapper<mpdb> lqwnew LambdaQueryWrapper<mpdb>();//模拟登陆查询等匹配lqw…

SELF-ATTENTION DOES NOT NEED O(n2) MEMORY

背景 主要是要解决self-attention空间复杂度的问题&#xff0c;因为对于gpu计算来说&#xff0c;内存空间非常宝贵&#xff0c;序列长度较长的时候会出现oom问题。 用线性时间解决self-attention问题 解决数据稳定问题 因为由于进行求和计算&#xff0c;容易导致浮点数超过最…

栈区和堆区以及注意事项

>>栈区 #include<stdio.h> #include<string.h> #include<stdlib.h>int* func() {int a 10;//栈上创建的变量return &a; }void test01() {int* p func();//结果早已不重要&#xff0c;因为上面的a早已被释放&#xff0c;再去操作这块内存属于//非…

行业追踪,2023-07-04,受特斯拉中报影响,汽车零部件放量强势拉升,不调整

自动复盘 2023-07-04 成交额超过 100 亿 排名靠前&#xff0c;macd柱由绿转红 成交量要大于均线 有必要给每个行业加一个上级的归类&#xff0c;这样更能体现主流方向 rps 有时候比较滞后&#xff0c;但不少是欲杨先抑&#xff0c; 应该持续跟踪&#xff0c;等 macd 反转时参与…

Gitbash常用指令总结

Part I git 开始的指令 1、git init&#xff1a;初始化一个Git仓库&#xff1b; 2、git clone&#xff1a;从远程仓库克隆代码到本地&#xff1b; 直接使用网址 git clone <url>or 用a代替网址 git remote add a <url>git clone a3、git add&#xff1a;添加文件到…

计算机基础--->数据结构(8)【B树、B+树<超详细图文>】

文章目录 B树(B-Tree)B树的查询操作B树的几种插入删除情况 B树B树的主要特点插入操作删除操作 B树(B-Tree) B树&#xff08;B-Tree&#xff09;是一种自平衡的搜索树&#xff0c;又称平衡多路查找树&#xff0c;主要用于系统中大量数据的读和写操作。B树的特点是能保持数据有序…

English-英语语法体系

语法体系 英语中的所有语句类型&#xff1a;什么怎么样 英语语法最重要的就是动词&#xff01;

3.4.流的学习,异步任务的管理

目录 前言1. 流总结 前言 杜老师推出的 tensorRT从零起步高性能部署 课程&#xff0c;之前有看过一遍&#xff0c;但是没有做笔记&#xff0c;很多东西也忘了。这次重新撸一遍&#xff0c;顺便记记笔记。 本次课程学习精简 CUDA 教程-流的学习&#xff0c;异步任务的管理 课程大…

MySQL库表操作作业

创建数据库 mysql> create database Market; mysql> use Market; 创建表和约束 mysql> create table customers(c_num int(11) primary key not null UNIQUE Key auto_increment , -> c_name varchar(50), -> c_city varchar(50), -> c_birth datetime…

九、HTML中的定位

1、定位 position static 默认值 没有使用定位 relactive 相对定位 absolute 绝对定位 fixed 锚定 标准文档流 标准文档流 从上到下&#xff0c;从左向右&#xff0c;依次显示网页中的每一个元素 元素分类 行内元素 依次一个挨着一个显示 块级元素 独占一行 static 定位 以…

【STM32智能车】智能寻迹

【STM32智能车】智能寻迹 基础算法寻迹小车 我们之前说了到了寻迹这里会涉及到一些算法&#xff0c;不过各位小伙伴可以放心&#xff0c;我们这里用的是一些基础算法。不需要公式&#xff0c;只需要进行简单的判断就行。 基础算法 寻迹车的程序算法如下&#xff1a; 初始化&…

MySQL数据库小练习1

1.创建数据库&#xff0c;删除数据库&#xff0c;查询创建数据的语句&#xff0c;使用数据库&#xff0c;查询当前默认的数据库以及使用的编码方式校验规则 创建数据库及使用数据库&#xff1a; create database hzc default character set utf8mb4 collate utf8mb4_0900_ai_…

uniapp电子签名以及竖屏签名后内容旋转90度变为横屏图片

用该插件挺不错的 电子签名插件地址 如果你一个页面要用多个该插件&#xff0c;就改成不同的cavas-id&#xff0c;修改插件源码 效果图 竖屏写 旋转成横屏图片 插件内 在拿到签名临时地址后的页面 <!-- 旋转图片canvas --> <canvas canvas-id"camCacnvs&quo…

第二次CCF计算机软件能力认证

第一题&#xff1a;相邻数对 给定 n 个不同的整数&#xff0c;问这些数中有多少对整数&#xff0c;它们的值正好相差 1。 输出格式 输入的第一行包含一个整数 n&#xff0c;表示给定整数的个数。 第二行包含所给定的 n 个整数。 输出格式 输出一个整数&#xff0c;表示值正好相…

华为OD计算工时python脚本

前言 刚入职不知道工时要平均每天满8小时&#xff0c;并且看不到每天的实际工时&#xff0c;一气之下花了一个中午写了个脚本计算每天的工时&#xff0c;分享一下&#xff0c;不同地区的兄弟需要修改一下午休和晚饭时间才能使用。 文件位置 把welink上 上下班时间输入work.c…

支持向量机推导之r||w||=1的限制转化

支持向量机推导之r||w||1的限制转化 很多同学肯定是学过支持向量机的&#xff0c;也可能大致的理解了支持向量机这个算法&#xff0c;我想大部分人在学习这个算法的时候&#xff0c;对于推导过程有一步应该是不太理解。 我先简要介绍一下SVM,SVM的核心思想在于找到一个多维空间…