详解MySQL常用的数据类型

news2024/11/25 21:34:55

图片

前言

MySQL是一个流行的关系型数据库管理系统,它支持多种数据类型,以满足不同数据处理和存储的需求。理解并正确使用这些数据类型对于提高数据库性能、确保数据完整性和准确性至关重要。本文将详细介绍MySQL中的数据类型,包括数值类型、字符串类型、日期和时间类型以及空间数据类型等,并探讨它们的优缺点、使用场景以及注意事项。

数据类型划分

MySQL的数据类型大致可以分为以下几类:

  • 数值类型:包括整数和浮点数类型,适用于存储各种数值数据。

  • 字符串类型:包括定长和可变长度的字符串,以及文本型数据。

  • 日期和时间类型:用于表示日期和时间信息。

  • 空间数据类型:用于地理空间数据的存储。

  • 二进制类型:适用于存储二进制数据,如图像或文件。

  • 特殊类型:例如JSON,用于存储特定格式的数据。

一、数值类型

数值类型包括精确数值类型(如INTEGER、DECIMAL)和近似数值类型(如FLOAT、DOUBLE)。

1. 精确数值类型

INTEGER:用于存储整数。

DECIMAL/NUMERIC:用于存储精确的小数。

示例:

CREATE TABLE example1 (      id INT,      price DECIMAL(10, 2)  );

注意点:DECIMAL类型需要指定精度和小数位数,以确保数据的准确性。

优缺点:精确度高,适用于需要精确计算的场景;但相对于近似数值类型,存储空间可能稍大。

使用场景:金融、会计等需要精确计算的领域。

2. 近似数值类型

FLOAT:单精度浮点数。

DOUBLE:双精度浮点数。

示例:

 CREATE TABLE example2 (       value FLOAT   );

注意点:由于浮点数在计算机中的表示方式,可能会存在精度问题。

优缺点:存储空间小,计算速度快;但精度不如精确数值类型。

使用场景:科学计算、物理模拟等对精度要求不是特别高的场景。

二、字符串类型

字符串类型包括CHAR、VARCHAR、TEXT等。

1. CHAR与VARCHAR

CHAR:定长字符串,长度固定。

VARCHAR:可变长字符串,长度可变。

示例:​​​​​​​

 CREATE TABLE example3 (       name CHAR(50),       description VARCHAR(255)   );

注意点:CHAR类型会占用固定长度的存储空间,即使实际数据长度小于指定长度;VARCHAR类型则根据实际数据长度来分配存储空间。

优缺点:CHAR类型查询速度快,但可能浪费存储空间;VARCHAR类型存储空间利用率高,但查询速度可能稍慢。

使用场景:CHAR适用于长度固定的数据,如身份证号;VARCHAR适用于长度可变的数据,如姓名、地址等。

2. TEXT类型

TEXT:用于存储长文本数据。

示例:​​​​​​​

 CREATE TABLE example4 (       content TEXT   );

注意点:TEXT类型适用于存储大量文本数据,但查询和处理速度可能不如CHAR和VARCHAR。

使用场景:文章、评论等需要存储大量文本的场景。

三、日期和时间类型

日期和时间类型包括DATE、TIME、DATETIME等。

示例:​​​​​​​

 CREATE TABLE example5 (  
     birthdate DATE,  
     event_time TIME,  
     registration_time DATETIME  
 );

注意点:不同的日期和时间类型有不同的存储范围和精度。

使用场景:记录用户生日、事件发生的具体时间等。

四、空间数据类型

GEOMETRY是MySQL中用于存储地理空间数据的数据类型。它是一个通用的地理空间数据类型,可以表示点、线、多边形等地理空间对象。GEOMETRY类型允许您在数据库中存储和查询地理空间数据,这对于地理信息系统(GIS)应用、地图应用以及需要空间查询和分析的应用非常有用。

示例:​​​​​​​

 CREATE TABLE example6 (  

     geom GEOMETRY  

 );

注意点:空间数据类型需要特定的GIS函数和工具来处理和查询。

使用场景:地理信息系统、地图应用等。

GEOMETRY相关函数使用

MySQL提供了一系列用于处理GEOMETRY类型数据的函数。以下是一些常用的函数及其用途:

1. ST_GeomFromText():用于从WKT(Well-Known Text)表示法创建GEOMETRY对象。

示例:

 SELECT ST_GeomFromText('POINT(1 1)');

2. ST_AsText():将GEOMETRY对象转换为WKT表示法。

示例:

 SELECT ST_AsText(ST_GeomFromText('POINT(1 1)'));

3. ST_Distance_Sphere():计算两个点之间的球面距离(以米为单位)。

示例:

SELECT ST_Distance_Sphere(ST_GeomFromText('POINT(0 0)'), ST_GeomFromText('POINT(1 1)'));

4. ST_Contains():检查一个GEOMETRY对象是否包含另一个GEOMETRY对象。

示例:

 SELECT ST_Contains(ST_GeomFromText('POLYGON((0 0, 1 0, 1 1, 0 1, 0 0))'), ST_GeomFromText('POINT(0.5 0.5)'));

5. ST_Intersection():返回两个GEOMETRY对象的交集。

示例:

SELECT ST_AsText(ST_Intersection(ST_GeomFromText('LINESTRING(0 0, 1 1)'), ST_GeomFromText('LINESTRING(0 1, 1 0)')));

6. ST_Buffer():返回与给定的GEOMETRY对象相距指定距离的缓冲区。

示例:

 SELECT ST_AsText(ST_Buffer(ST_GeomFromText('POINT(0 0)'), 1));

 这些函数只是MySQL提供的一部分空间函数,实际上还有更多的函数可用于处理和分析地理空间数据。可以通过查阅MySQL的官方文档来了解更多关于这些函数的信息和用法。

请注意,为了使用这些空间函数,需要确保MySQL服务器已经启用了空间扩展,并且表已经使用了适当的空间索引来优化空间查询的性能。

五、二进制类型

适用于存储二进制数据,如图像或文件。但查询和操作不如文本类型方便。

示例:​​​​​​​

CREATE TABLE example (

    id INT(11) NOT NULL AUTO_INCREMENT,

    binary_col BINARY(10),

    varbinary_col VARBINARY(10),

    blob_col BLOB,

    PRIMARY KEY (id)

);

使用场景:适用于非文本数据的存储,如图片、文件等。

六、特殊类型

例如JSON,用于存储特定格式的数据。

示例:

CREATE TABLE example (

    id INT(11) NOT NULL AUTO_INCREMENT,

    json_col JSON,

    PRIMARY KEY (id)

);

​​​​使用场景:JSON类型适用于存储结构化复杂的数据。比如存储用户的配置文件、产品的详细信息、订单详情等。

JSON常用的函数:

1. JSON_EXTRACT(json_doc, path[, path] ...) 或 ->:从JSON文档中提取指定路径的值。

示例:​​​​​​​

 SELECT JSON_EXTRACT('{"name": "John", "age": 30}', '$.name');  
 -- 或者  
 SELECT '{"name": "John", "age": 30}'->'$.name';

2. JSON_SET(json_doc, path, val[, path, val] ...):插入或更新JSON文档中的值。

示例:

 SELECT JSON_SET('{"name": "John"}', '$.age', 30);

3. JSON_REPLACE(json_doc, path, val[, path, val] ...):替换JSON文档中的值。

示例:

SELECT JSON_REPLACE('{"name": "John", "age": 30}', '$.age', 35);

4. JSON_REMOVE(json_doc, path[, path] ...):从JSON文档中删除指定路径的值。

示例:

 SELECT JSON_REMOVE('{"name": "John", "age": 30}', '$.age');

5. JSON_KEYS(json_doc[, path]):返回JSON文档中指定路径的所有键。

示例:

 SELECT JSON_KEYS('{"name": "John", "age": 30}');

6. JSON_ARRAY([val[, val] ...]):创建一个JSON数组。

示例:

 SELECT JSON_ARRAY(1, 'a', true);

7. JSON_OBJECT([key, val[, key, val] ...]):创建一个JSON对象。

示例:

SELECT JSON_OBJECT('name', 'John', 'age', 30);

8. JSON_VALID(json_val):检查给定的字符串是否是有效的JSON文档。

示例:

 SELECT JSON_VALID('{"name": "John", "age": 30}');

9. JSON_CONTAINS(json_doc, val[, path]):检查JSON文档是否包含特定值。

示例:

 SELECT JSON_CONTAINS('{"name": "John", "age": 30}', '"John"');

10. JSON_CONTAINS_PATH(json_doc, one_or_all, path[, path] ...):检查JSON文档是否包含特定路径。

示例:

 SELECT JSON_CONTAINS_PATH('{"name": "John", "age": 30}', 'one', '$.name');

这些函数只是MySQL JSON功能的一部分,实际上还有更多函数可用于处理JSON数据。可以查阅MySQL官方文档以获取完整的函数列表和详细的使用说明。

结语

MySQL的数据类型丰富多样,每种类型都有其特定的应用场景和优缺点。在实际应用中,我们需要根据数据的性质、存储需求以及查询性能要求来选择合适的数据类型。通过合理使用数据类型,我们可以提高数据库的性能,确保数据的完整性和准确性,为应用提供稳定可靠的数据支持。

图片

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

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

相关文章

算法分析 KMP算法中next值的计算、0/1背包问题

5.6.1 KMP算法中next值的计算 设模式的长度为m。用蛮力法求解 KMP算法中的 next值时&#xff0c;next[0]可直接给出&#xff0c;计算next[j](1<j<m-1)则需要在 T[0] …T[j-1]中分别取长度为j-1、..、2、1的真前缀和真后缀并比较是否相等&#xff0c;最坏情况下的时间代价…

2024------MySQL数据库基础知识点总结

-- 最好的选择不是最明智的&#xff0c;而是最勇敢的&#xff0c;最能体现我们真实意愿的选择。 MySQL数据库基础知识点总结 一、概念 数据库&#xff1a;DataBase&#xff0c;简称DB。按照一定格式存储数据的一些文件的组合顾名思义: 存储数据的仓库&#xff0c;实际上就是一…

Java初识继承

继承 文章目录 继承为什么需要继承继承中变量的访问特点继承中方法的访问特点继承的优缺点 概念:在Java中&#xff0c;继承是面向对象编程的一个基本特性。它允许我们定义一个新类&#xff0c;它从另一个已经存在的类继承其属性和方法。被继承的类称为父类或超类&#xff0c;新…

Linux进程——Linux进程与进程优先级

前言&#xff1a;在上一篇了解完一部分常见的进程状态后&#xff0c;我们先来把剩下的进程状态了解一下&#xff0c;再来进入进程优先级的学习&#xff01; 如果对前面Linux进程不太熟悉可以先阅读&#xff1a; Linux进程 本篇主要内容&#xff1a; 僵尸进程和孤儿进程 Linux进…

63-HDMI转VGA电路设计

视频链接 HDMI转VGA电路设计01_哔哩哔哩_bilibili HDMI转VGA电路设计 HDMI电路设计&#xff08;参考第13课&#xff09; VGA电路设计&#xff08;参考第15课&#xff09; DP转VGA电路设计&#xff08;参考第75课&#xff09; 1、HDMI转VGA转换器 2、HDMI转VGA简介 1、解…

融知财经:期货风险有多大,期货风险进行控制的方法

期货价格变化远大于股票市场&#xff0c;其风险也大于股票市场&#xff0c;当然其预期收益机会相对较高&#xff0c;因此期货更适合激进型投资者。在期货投资市场中&#xff0c;除了市场外的常见风险外&#xff0c;转型期投资者的投机心理和杠杆效应会增加期货的交易风险&#…

获取波形极值与间距并显示

获取并显示波形的极值与极值间距 1、流程 1、通过signal.find_peaks获取极大值 2、获取极大值下标 3、获取极大值对应的值 4、获取极大值的下标间距(就是隔多远有一个极大值) 5、获取极大值间距的标准差、方差、均值、最大值 6、图形展示波形图并标记极大值2、效果图 3、示…

铜价飙升,慧能泰HUSB332F带你狂飙

铜价&#xff0c;近期涨的很飘&#xff0c;涨到怀疑人生。继黄金后&#xff0c;铜成了另一个疯涨的明星&#xff01;作为电线电缆生产不可或缺的原材料&#xff0c;铜的身价暴涨直接拉响了成本警报&#xff0c;压缩了企业的利润空间。众多电线电缆制造商面临着严峻的挑战与考验…

嵌入式学习<1>:建立工程、GPIO

嵌入式学习_part1 本部分笔记用于学习记录&#xff0c;笔记源头 >>b站江科大_STM32入门教程 建立工程、GPIO 开发环境&#xff1a;keil MDK、STM32F103C8T6 1 &#xff09;建立工程 &#xff08;1&#xff09;基于寄存器开发、基于标准库 或者 基于HAL库开发; &…

【Python】字典题

题目&#xff1a;输入一段文本&#xff0c;统计每个字符的个数 in_inputinput(“输入&#xff1a;”) dic{} for char in in_input: if char in dic: dic[char]1 # 字典添加键值对的方法&#xff0c;给字典给键和值的方法 else: dic[char]1 print(dic) for key,value in dic.i…

Elastic 通过 AI 驱动的安全分析改变 SIEM 游戏

作者&#xff1a;Santosh Krishnan, Jennifer Ellard 借助由搜索 AI 提供支持的新攻击发现功能&#xff0c;优先考虑攻击&#xff0c;而不是警报。 传统的安全信息与事件管理系统&#xff08;SIEM&#xff09;在很大程度上依赖屏幕背后的人类才能取得成功。警报、仪表盘、威胁…

DCEP数字人民币:中国法定区块链中数字货币

一、背景 作为全球第二大经济体&#xff0c;中国在数字货币领域的发展一直备受关注。近年来&#xff0c;中国政府积极推动数字货币的研究和试点工作&#xff0c;逐步开放数字货币交易试点&#xff0c;并计划推出中国唯一合法数字货币——数字人民币&#xff08;RMB Coin&#…

tcping的安装,ping和tcping的区别

ping和tcping的区别 功能不同&#xff1a; Ping&#xff1a;Ping是一种基于ICMP协议的网络工具&#xff0c;用于测试主机之间的连通性。它发送ICMP回显请求&#xff08;Echo Request&#xff09;到目标主机&#xff0c;并等待目标主机返回ICMP回显应答&#xff08;Echo Reply…

【Unity】使用Resources.LoadAll读取文件的顺序问题

最近在做客户的一个项目&#xff0c;其中的一个模块使用到了照片&#xff0c;但是发现了一个很严重的问题。当你在使用Unity的时候&#xff0c;它竟然不按照顺序读取&#xff1f;这个机器人是不是逻辑有问题&#xff1f;如下图&#xff1a; 名字脱敏了哈。。。 照片比较多&…

订单超时自动取消的实践方案

1、定时任务方案 方案流程&#xff1a; 每隔 30 秒查询数据库&#xff0c;取出最近的 N 条未支付的订单。 遍历查询出来的订单列表&#xff0c;判断当前时间减去订单的创建时间是否超过了支付超时时间&#xff0c;如果超时则对该订单执行取消操作。 定时任务方案工程实现相…

DAPP开发:揭秘DAPP软件开发的秘密

随着区块链技术的飞速发展&#xff0c;DAPP&#xff08;去中心化应用&#xff09;的开发逐渐成为了一个热门话题。在本文中&#xff0c;我们将探讨如何从零开始开发DAPP软件&#xff0c;并深入思考DAPP开发中的关键问题。 一、了解DAPP开发的基础知识 在开始开发DAPP之前&…

Web3:下一代互联网的科技进化

随着科技的不断演进&#xff0c;互联网已经成为了我们生活中不可或缺的一部分。而在Web3时代&#xff0c;我们将会见证互联网进化的下一个阶段。本文将探讨Web3作为下一代互联网的科技进化&#xff0c;以及它所带来的重要变革和影响。 传统互联网的局限性 传统互联网存在诸多…

绘画作品3d数字云展厅提升大众的艺术鉴赏和欣赏能力

3D虚拟展厅作为未来艺术的展示途径&#xff0c;正逐渐成为文化创意产业蓬勃发展的重要引擎。这一创新形式不仅打破了传统艺术展览的局限性&#xff0c;更以其独特的魅力吸引着全球观众的目光。 3D虚拟艺术品展厅以其独特的魅力&#xff0c;助力提升大众的艺术鉴赏和欣赏能力。观…

开发组合php+mysql 人才招聘小程序源码搭建 招聘平台系统源码+详细图文搭建部署教程

随着互联网的快速发展&#xff0c;传统的招聘方式已经不能满足企业和求职者的需求。为了提高招聘效率&#xff0c;降低招聘成本&#xff0c;越来越多的人开始关注人才招聘小程序、在线招聘平台。分享一个人才招聘小程序源码及搭建&#xff0c;让招聘更加高效便捷。系统是运营级…

Android getevent命令详细分析

在调试Android 的输入事件时&#xff0c;经常使用 “getevent -lrt” 命令&#xff0c;来确认驱动上报数据是否正常。从源码的角度来详细的分析一下getevent 这个程序。 首先用ls命令来看一下getevent lrwxr-xr-x 1 root shell 7 2023-11-20 10:08 system/bin/getevent -> …