MySQL系列之数据类型(Numeric)

embedded/2024/12/21 15:38:27/

导览

  • 前言
  • 一、数值类型综述
  • 二、数值类型详解
    • 1. NUMERIC
    • 2. Integer类型取值和存储要求
    • 3. Fixed-Point类型取值和存储要求
    • 4. Floating-Point类型取值和存储要求
  • 结语
  • 精彩回放

前言

MySQL系列最近三篇均关注了和我们日常工作或学习密切相关的安全话题,通过介绍相关领域知识或实践,为有需要的盆友提供便捷的参考方案。

从本文开始,博主打算换个“口味”,正如吃饭需要“酸甜苦辣咸”一样,数据类型(Data Types)是MySQL存储的基本标准。今天博主带着各位先深入学习其中之一:Numeric
在这里插入图片描述

一、数值类型综述

MySQL支持数值类型,主要包括两类:

  • 精确的数值数据类型
    INTEGER、SMALLINT、DECIMAL和NUMERIC
  • 近似的数值数据类型
    FLOAT、REAL和DOUBLE PRECISION

二、数值类型详解

1. NUMERIC

1.1 UNSIGNED或SIGNED

Numeric类型允许UNSIGNED(无符号)和SIGNED(有符号)。其中SIGNED是默认属性,UNSIGNED用于限制数值为非负。它们的区别就是UNSIGNED扩展了整型数据的可用范围,但是并没有改变类型存储的数据范围。

1.2 数据类型划分

Numeric包括以下主要的数据类型

类型说明
BIT位,取值[1,64],默认是1
TINYINT短整数,取值[-128,127] ;如无符号,取值[0,255]
BOOL,BOOLEAN等同TINYINT[1],0代表false,非0代表1
SMALLINT短整数,取值[-32768,32767] ;如无符号,取值[0,65535]
MEDIUMINT中等整数,取值[-8388608,8388607] ;如无符号,取值[ 0,16777215]
INT,INTEGER正常整数,取值[-2147483648,2147483647] ;如无符号,取值[ 0,4294967295]
BIGINT长整数,取值[ -9223372036854775808,9223372036854775807] ;如无符号,取值[0,18446744073709551615]
DECIMAL一个“固定”的浮点数,支持的最大长度65(默认10),最大的小数位数30(默认0)
FLOAT一个单精度浮点数,取值[3.402823466E+38,-1.175494351E-38]和[1.175494351E-38,3.402823466E+38],可精确到小数点7位左右。该类型的数据精度随硬件或操作系统的差异会有所不同
DOUBLE一个双精度浮点数,取值[-1.7976931348623157E+308,-2.2250738585072014E-308]和[0,2.225073585072014E-308-1797693134863157E+308],可精确到小数点15位左右

2. Integer类型取值和存储要求

在这里插入图片描述

3. Fixed-Point类型取值和存储要求

DECIMALNUMERIC类型可以存储精确的浮点数据,如金额类数据。比如创建一个注册资本字段:regcap decimal(10,2),代表长度为10位,并保留2位小数。

提示:在MySQL中,NUMERIC等同于DECIMAL。

4. Floating-Point类型取值和存储要求

FLOATDOUBLE类型表示近似的数值。在MySQL中,使用四个字节表示单精度值,八个字节表示双精度值。
比如我们定义一个类型为*float(10,5)*的字段,实际会存入一个近似值。

结语

本文对MySQL数据类型中的Numeric进行了说明,可以指导我们在建库建表的时候,针对不同业务字段设计不同的Numeric类型。

走过的、路过的盆友们,点点赞,收收藏,并加以指导,以备不时之需哈~


精彩回放


MySQL系列之远程管理(安全)
MySQL系列之身份鉴别(安全)
MySQL系列之数据授权(安全)
MySQL系列之如何在Linux只安装客户端
MySQL系列之如何正确的使用窗口函数(基于8.0版本)
MySQL系列之数据导入导出
MySQL系列之索引入门(上)
MySQL系列之索引入门(下)


在这里插入图片描述


http://www.ppmy.cn/embedded/147562.html

相关文章

存储过程(详细-附样例)

所有样例都是在mysql5.7版本下执行的,如果用其他数据库,请根据对应的数据库存储过程定义更改语句。 主体目录 一、存储过程相关命令 二、存储过程 2、参数 3、变量 4、if 流程控制 5、case 条件控制 6、while 循环语句 7、repeat 循环语句 8、…

云计算HCIP-OpenStack03

书接上回: 云计算HCIP-OpenStack02-CSDN博客 10.KeyStone keystone-Openstack,IAM服务(统一身份认证)-云服务 建议先去了解Hadoop(大数据生态系统)中的kerberos(LDAPkerberos的鉴权机制&#xf…

vue-element-admin npm install 安装失败,tui-editor更名导致

导语: 本失败原因是由于tui-editor(富文本编辑器插件)更名造成的,现在已经更名为toast-ui/editor; 在一个是一直以为是我的git问题 报错代码:code 128 ..........,困扰了我好长时间&#xff…

分布式链路追踪简介-01-dapper 论文思想介绍

开源项目 auto-log 自动日志输出 分布式链路追踪简介 随着业务系统的不断发展、微服务架构的演进,从原来的单体应用架构、垂直应用架构、分布式 SOA 架构到现在的微服务架构,系统逐步走向微服务化以适应用户高并发请求等需求。 在微服务架构中&#…

【C#】方法参数的修饰符ref 与 out

在 C# 中,ref 和 out 是方法参数的修饰符,用于将参数 按引用传递,而不是按值传递。这允许方法修改调用者传递的变量的值。尽管它们的行为类似,但有重要的区别和适用场景。 1. ref 的含义与使用 含义 引用传递: 参数通…

将HTML转换为PDF:使用Spire.Doc的详细指南(二)无水印版

目录 引言 一、准备工作 1. 下载Spire.Doc for Java破解版 2. 将JAR包安装到本地Maven (1) 打开命令提示符 (2) 输入安装命令 (3) 在pom.xml中导入依赖 二、实现HTML到PDF的转换 1. 创建Java类 2. 完整代码示例 3. 代码解析 4. 处理图像 5. 性能优化 6. 错误处理…

TCP三次握手,四次挥手

三次握手 第一次握手:客户端向服务器发送一个 SYN 包,其中 SYN 标志位被设置为 1,表示客户端请求建立连接,并随机生成一个初始序列号 seqx 。此时客户端进入 SYN_SENT 状态,等待服务器的确认1.第二次握手:服…

数据云平台的可观测性

在数据驱动的世界中,企业依赖数据云平台来处理、存储和分析大量数据。数据云平台的可观测性变得尤为重要,因为它不仅能帮助企业实时监控数据流和系统性能,还能提高故障诊断和系统优化的效率。 本文将探讨数据云平台可观测性的关键性、其三大…