MySQL:数据类型

文章目录

  • 数据类型分类
  • 数值类型
  • 越界访问
  • bit类型
  • 小数类型
    • float
    • decimal
  • 字符串类型
    • char
    • varchar
  • 日期
  • enum和set

数据类型分类

在MySQL数据库中,存在各种各样的数据类型:

在这里插入图片描述

针对于上述的这么多类型,本篇就对于这些类型的数据进行一一解释,并解释其当中的特性

数值类型

在这里插入图片描述
以上展示的是在MySQL中的数值类型以及对应的最大最小值,从中可以看出是和C语言有很多相似的地方的,那么接下来就设计一组越界测试来检验最大最小值

越界访问

普通越界访问

在这里插入图片描述
这里我创建了一个数据库,并尝试向tinyint中插入对应的数据,此时发现插入是失败的,这是因为超过了一个字节对应的最大存储值,换句话说MySQL并不允许插入一个不符合范围的数据

换句话说,MySQL中和C语言不一样,在C语言中如果使用的是超过接线的数字,最多是会提示一个告警的信息,在具体的处理中会有截断或者是隐式类型转换这样的操作,但是不管怎么说,终是可以容纳进去的,但是在MySQL中这样的操作是不合法,也是不可接受的

如果向MySQL中插入不合法的数据,那么MySQL会直接拦截,不让这样的操作继续向后执行,换句话说,如果有数据被成功插入MySQL当中了,那么就意味着这个数据一定是合法的

所以,MySQL的数据类型本身也是一种约束,这样就能保证数据库中的数据都是可预期,完整的数据,同时也会使得程序员必须要进行数据的正确插入,约束使用者

无符号和有符号数

在这里插入图片描述

bit类型

下面介绍的这种数据类型是bit类型,它表示的是位字段类型,其中可以指定这个类型中有多少个比特位,如果不设置默认是1个比特位:

在这里插入图片描述
由上面的现象可以得出一个结论,在bit位段进行显示的时候,会按照ASCII对应的值来进行显示,在未来,如果有需要的使用场景,填入的数据只有0或者1这两种可能,此时就可以插入一个bit位1的位段,那么表示的就是这个位置填入的数据不是0就是1,这样可以节省空间

在这里插入图片描述
从上述用例可以看出,这部分的内容也是遵守界限规则的

小数类型

float

对于float,在C语言中表示的是浮点数,而在MySQL语句中略有不同,在定义的时候要制定对应的显示长度,小数位数,float类型占用空间是4个字节

在这里插入图片描述
以上述的float类型的数据范围是4, 2为例,它表示的意思是该浮点数显示的是4位,并且有效精度是2位,那么对于这个测试来说,它所能表示的范围就是-99.99到99.99,值得注意的是,这个是遵循四舍五入原则的,如果插入的是99.991,其实也是可以插入的,但是如果是99.995,就不可以了

无符号float

在这里插入图片描述
对于无符号的类型数据来说,其实就是把数据范围中的负数部分去掉了,只能选正数的部分

decimal

以上是对float的理解,那么下面介绍的数据类型是decimal

它定义的方法和float是一样的,但是区别是,它表示的精度和float并不相同:

在这里插入图片描述
从中看出,它们两个类型的区分之一就是精度不一样,这是由于float内部的存储模式决定的,float表示的精度最大是7位左右,而对应的decimal可以容纳的是65,小数最大是30位

所以,当需要使得小数的精度更高的时候,推荐使用的是decimal

字符串类型

char

在这里插入图片描述
从中可以看出的规律是,char(2)表示可以存放的是两个字符,可以是字母或者汉字,最长是255

varchar

在这里插入图片描述
看似它和char作用是一样的,那么具体的有什么不同点呢?

在这里插入图片描述
变长的意义就是,在不超过自定义范围的情况下,用多少开辟多少,而定长就是直接先都开辟好了

日期

常用的日期有三个

  1. date
  2. datetime
  3. timestamp

在这里插入图片描述
需要注意的是,t3表示的时间戳类型,它会自动在你插入数据打的时候进行更新,更新的就是当前的时间

enum和set

对于enum其实并不陌生,它表示的就是枚举,所以这里不再进行赘述,和c中的用法是一样的,这个设定提供了若干个选项的值,在最终的单元格中,只是存储了数字

那这个set表示的类型是集合的意思,就是提供了若干的选项,可以从中进行挑选等

find_in_set函数

这个函数从名字就能看出,它主要是为了在集合中查找元素而服务的,一般格式为

find_in_set(sub,str_list):如果这个sub在str_list当中,那么就返回下标,如果不存在就返回0

在这里插入图片描述

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

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

相关文章

uView Layout 布局

通过基础的 12 分栏,迅速简便地创建布局 注意 如需实现类似宫格的布局,请使用uView的Grid宫格组件,可以设置角标,功能更完善和灵活 #平台差异说明 App(vue)App(nvue)H5小程序√√…

STM32--RC522学习记录

一&#xff0c;datasheet阅读记录 1.关于通信格式 2.读寄存器 u8 RC522_ReadReg(u8 address) {u8 addr address;u8 data0x00;addr((addr<<1)&0x7e)|0x80;//将最高位置一表示read&#xff0c;最后一位按照手册建议变为0Spi_Start();//选中从机SPI2_ReadWriteByte(ad…

javaSwing宿舍管理系统(三个角色)

一、 简介 宿舍管理系统是一个针对学校宿舍管理的软件系统&#xff0c;旨在方便学生、宿管和管理员进行宿舍信息管理、学生信息管理以及宿舍评比等操作。该系统使用 Java Swing 进行界面设计&#xff0c;分为三个角色&#xff1a;管理员、宿管和学生。 二、 功能模块 2.1 管…

2024.03.08 校招 实习 内推 面经

绿*泡*泡VX&#xff1a; neituijunsir 交流*裙 &#xff0c;内推/实习/校招汇总表格 1、校招&实习 | 小马智行Pony.ai 2024春季校园招聘启动&可转正实习&#xff08;内推&#xff09; 校招&实习 | 小马智行Pony.ai 2024春季校园招聘启动&可转正实习&#x…

面向中文大模型价值观的评估与对齐研究:“给AI的100瓶毒药”并解毒,守护AI纯净之心

面向中文大模型价值观的评估与对齐研究&#xff1a;“给AI的100瓶毒药”并解毒&#xff0c;守护AI纯净之心 1.简介 随着Large Language Models&#xff08;LLMs&#xff09;的快速发展&#xff0c;越来越多的人开始担心它们可能带来风险。因此&#xff0c;围绕大模型的“安全…

Pytorch 中的forward 函数内部原理

PyTorch中的forward函数是nn.Module类的一部分&#xff0c;它定义了模型的前向传播规则。当你创建一个继承自nn.Module的类时&#xff0c;你实际上是在定义网络的结构。forward函数是这个结构中最关键的部分&#xff0c;因为它指定了数据如何通过网络流动。 单独设计 forward …

Collection与数据结构 数据结构预备知识(一) :集合框架与时间空间复杂度

1.集合框架 1.1 什么是集合框架 Java集合框架,又被称为容器,是定义在java.util包下的一组接口和接口实现的一些类.其主要的表现就是把一些数据放入这些容器中,对数据进行便捷的存储,检索,管理.集合框架底层实现原理其实就是各种数据结构的实现方法,所以在以后的学习中,我们会…

QT(3/22)

1>使用手动连接&#xff0c;将登录框中的取消按钮使用qt4版本的连接到自定义的槽函数中&#xff0c;在自定义的槽函数中调用关闭函数&#xff0c;将登录按钮使用qt5版本的连接到自定义的槽函数中&#xff0c;在槽函数中判断ui界面上输入的账号是否为"admin"&#…

网络编程中的序列化、反序列化与协议

网络编程中的序列化、反序列化与协议 1. 序列化和反序列化的概念2. 序列化、反序列化与协议的关系3. JSON与网络通信 在网络编程中&#xff0c;序列化和反序列化与协议密切相关&#xff0c;它们共同构成了数据在网络中传输的基础。本文将详细介绍序列化、反序列化以及它们与协议…

StarRocks 助力金融营销数字化进化之路

作者&#xff1a;平安银行 数据资产中心数据及 AI 平台团队负责人 廖晓格 平安银行五位一体&#xff0c;做零售金融的领先银行&#xff0c;五位一体是由开放银行、AI 银行、远程银行、线下银行、综合化银行协同构建的数据化、智能化的零售客户经营模式&#xff0c;这套模式以数…

人工智能大模型学习:在自然语言处理、图像识别与语音识别中的应用及未来展望

在当前技术环境下&#xff0c;人工智能&#xff08;AI&#xff09;已成为推动各行各业进步的关键力量。AI的大模型学习特别引人注目&#xff0c;它不仅要求研究者具备深厚的数学基础和编程能力&#xff0c;还需要对特定领域的业务场景有深入的了解。这种复合型知识结构使得AI大…

【Hadoop大数据技术】——Hadoop高可用集群(学习笔记)

&#x1f4d6; 前言&#xff1a;Hadoop设计之初&#xff0c;在架构设计和应用性能方面存在很多不如人意的地方&#xff0c;如HDFS和YARN集群的主节点只能有一个&#xff0c;如果主节点宕机无法使用&#xff0c;那么将导致HDFS或YARN集群无法使用&#xff0c;针对上述问题&#…

值得参考的golang语言开发规范:Uber Go 语言编码规范,一些优秀的技巧可以提升代码的质量、避免代码缺陷和bug漏洞

值得参考的golang语言开发规范&#xff1a;Uber Go 语言编码规范&#xff0c;一些优秀的技巧可以提升代码的质量、避免代码缺陷和bug漏洞。 Uber Go 语言编码规范 Uber 是一家美国硅谷的科技公司&#xff0c;也是 Go 语言的早期 adopter。其开源了很多 golang 项目&#xff0c;…

Java图的遍历知识点(含面试大厂题和源码)

图的遍历是图论中的一个基本概念&#xff0c;主要指的是按照某种规则&#xff0c;系统地访问图中的每一个顶点&#xff0c;且每个顶点仅被访问一次。图遍历的主要目的是为了搜索图中的信息或检查图中是否存在特定的路径或圈。图的遍历算法主要有两种&#xff1a;深度优先搜索&a…

Linux简单基础配置

以下配置一般需要切换为root用户下进行。 1、修改主机名 node1主机终端执行: hostnamectl set-hostname node1 node2主机终端执行: hostnamectl set-hostname node2 node3主机终端执行: hostnamectl set-hostname node3 2、配置固定IP vim /etc/sysconfig/network-scripts…

UE5 LiveLink 自动连接数据源,以及打包后不能收到udp消息的解决办法

为什么要自动连接数据源&#xff0c;因为方便打包后接收数据&#xff0c;这里我是写在了Game Instance,也可以写在其他地方&#xff0c;自行替换成Beginplay和Endplay 关于编辑器模式下能收到udp消息&#xff0c;打包后不能收到消息的问题有两点需要排查&#xff0c;启动打包后…

Jmeter脚本优化——CSV数据驱动文件

使用 CSV 数据文件设置实现参数化注册 1&#xff09; 本地创建 csv 文件&#xff0c;并准备要使用的数据&#xff0c;这里要参数化的是注册的用户名和邮箱。所以在 csv 文件中输入多组用户名和邮箱。 2&#xff09; 通过测试计划或者线程组的右键添加->配置元件->CSV…

亚信安慧AntDB解析:数据库技术的新里程碑

AntDB简化了开发运维&#xff0c;更提高了数据库的易用性。AntDB是一种创新的数据库管理系统&#xff0c;其设计理念旨在让用户能够更便捷地进行数据库操作&#xff0c;减少繁琐的配置和管理工作&#xff0c;提升工作效率。 通过AntDB&#xff0c;用户可以快速部署和管理数据库…

AI大模型的看法

现在的AI大模型行情可谓如火如荼&#xff0c;吸引了众多科技巨头和投资者的目光。随着大数据和计算力的不断提升&#xff0c;AI大模型在语音识别、自然语言处理、图像识别等领域取得了显著进展&#xff0c;为各行各业带来了前所未有的机遇。 在技术栈方面&#xff0c;AI大模型主…

Py之scikit-learn-extra:scikit-learn-extra的简介、安装、案例应用之详细攻略

Py之scikit-learn-extra&#xff1a;scikit-learn-extra的简介、安装、案例应用之详细攻略 目录 scikit-learn-extra的简介 scikit-learn-extra的安装 scikit-learn-extra的案例应用 1、使用 scikit-learn-extra 中的 IsolationForest 模型进行异常检测 scikit-learn-extra…