当前位置: 首页 > news >正文

MySQL系列之数据类型(Numeric)

导览

  • 前言
  • 一、数值类型综述
  • 二、数值类型详解
    • 1. NUMERIC
      • 1.1 UNSIGNED或SIGNED
      • 1.2 数据类型划分
    • 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.lryc.cn/news/492001.html

相关文章:

  • BERT简单理解;双向编码器优势
  • LLamafactory 批量推理与异步 API 调用效率对比实测
  • spf算法、三类LSA、区间防环路机制/规则、虚连接
  • C语言学习 12(指针学习1)
  • TypeError: issubclass() arg 1 must be a class
  • Java面试题、八股文学习之JVM篇
  • 【eNSP】动态路由协议RIP和OSPF
  • 春秋云境 CVE 复现
  • Linux入门攻坚——39、Nginx入门
  • 计算机网络的类型
  • 解决 MySQL 5.7 安装中的常见问题及解决方案
  • VITE+VUE3+TS环境搭建
  • 【设计模式】【创建型模式(Creational Patterns)】之原型模式(Prototype Pattern)
  • 黄仁勋:人形机器人在内,仅有三种机器人有望实现大规模生产
  • 【C语言】宏定义详解
  • LangChain——多向量检索器
  • 《岩石学报》
  • 数据结构 (12)串的存储实现
  • 职场发展陷阱
  • Xcode15(iOS17.4)打包的项目在 iOS12 系统上启动崩溃
  • 极狐GitLab 17.6 正式发布几十项与 DevSecOps 相关的功能【二】
  • PVE相关名词通俗表述方式———多处细节实验(方便理解)
  • Ansible--自动化运维工具
  • 微信小程序学习指南从入门到精通
  • 微服务篇-深入了解使用 RestTemplate 远程调用、Nacos 注册中心基本原理与使用、OpenFeign 的基本使用
  • 使用 Django 构建支持 Kubernetes API 测试连接的 POST 接口
  • 十二、正则表达式、元字符、替换修饰符、手势和对话框插件
  • 计算机毕业设计Python+大模型美食推荐系统 美食可视化 美食数据分析大屏 美食爬虫 美团爬虫 机器学习 大数据毕业设计 Django Vue.js
  • 【后端面试总结】MySQL索引
  • [蓝桥杯 2021 省 AB2] 小平方