优化SQL查询实现高效数据检索(二)

news2024/11/26 10:28:36

大家好,本文将接着上文,继续介绍SQL查询优化的重要性以及如何优化SQL查询以实现更快的数据检索。

  • 适当使用通配符

适当使用通配符对于优化SQL查询尤为重要,特别是在匹配字符串和模式方面。通配符是用于SQL查询中查找特定模式的特殊字符,SQL中最常见的通配符是“%”和“_”,其中“%”表示任何字符序列,“_”表示单个字符。明智地使用通配符很重要,因为不当使用可能会导致性能问题,特别是在大型数据库中。然而,有效地使用它们可以极大地提高字符串匹配和模式匹配查询的性能。

现在让我们看一个实例,此查询使用RIGHT()函数来提取customer_name列的最后三个字符,然后检查它是否等于“son”。

SELECT customer_name
FROM customer
WHERE RIGHT(customer_name, 3) = 'son';

 以下是输出结果:

 

尽管此查询实现了所需的结果,但它并不那么高效,因为必须将RIGHT()函数应用于表中的每一行。让我们通过使用通配符来优化我们的代码:

SELECT customer_name
FROM customer
WHERE customer_name LIKE '%son';

以下是输出结果:

 

这个优化后的SQL查询使用LIKE运算符和通配符“%”来搜索customer_name列以“son”结尾的记录。这种方法更有效,因为它利用了数据库引擎的模式匹配能力,并且如果有索引可用,它可以更好地利用索引。

正如我们所看到的,总查询时间从436毫秒降低到62毫秒,快了近7倍。

  • 使用Top或LIMIT来限制样本结果的数量

使用TOP或LIMIT来限制样本结果对于优化SQL查询尤为重要,特别是在处理大型表时,这些子句允许你仅从表中检索指定数量的记录,而不是所有记录,这对性能是有益的。

现在从customer表中检索所有信息:

SELECT *
FROM customer

以下是输出结果:
 

 

当处理较大的表时,此操作可能会增加I/O和网络延迟,这可能会降低SQL查询性能。现在通过将输出限制为10来优化我们的代码:

SELECT *
FROM customer
LIMIT 10;

 以下是输出结果:

 

通过限制输出,将减少网络延迟和内存使用,并提高响应时间,尤其是在处理大型表时。在我们的实例中,经过SQL查询优化后,总查询运行时间从260毫秒降低到89毫秒,查询速度变得几乎快了3倍。

  • 使用索引

这次将识别并为使用WHEREJOINORDER BY子句中的列创建适当的索引,以提高查询性能。通过对经常访问的列进行索引,数据库可以更快地检索数据。首先运行以下查询:

SELECT customer_id, 
       customer_name
FROM customer
WHERE segment = 'Corporate';

 以下是输出结果:

 

查询运行时间为259毫秒,试着通过创建索引来改善这一情况:

CREATE INDEX idx_segment ON customer (segment);
SELECT customer_id, 
       customer_name
FROM customer WITH (INDEX(idx_segment))
WHERE segment = 'Corporate';

以下是输出结果:

 通过在INDEX()中使用idx_segment,数据库引擎能够根据segment列高效地搜索customer表,从而使查询运行更快,将总查询时间从259毫秒降低到75毫秒。

使用SQL查询优化工具

由于长代码和高度复杂的查询的复杂性,你可能需要考虑使用查询优化工具。

这些工具可以分析你的查询执行计划,识别缺失的索引,并建议替代查询结构以帮助优化你的查询。一些流行的查询优化工具包括:

1.SolarWinds Database Performance Analyzer:该工具可帮助你监视和改善数据库性能。它显示查询问题以及它们的运行方式。它适用于多种数据库系统,如SQL Server、Oracle和MySQL。

2.SQL Query Tuner for SQL Diagnostic Manager:该工具具有使查询工作得更好的高级功能,如性能提示、索引检查和显示查询运行方式。它通过查找和修复问题来帮助你使SQL查询变得更好。

3.SQL Server Management Studio (SSMS):SSMS具有可检查性能并改善查询的内置工具,如活动监视器、执行计划分析和索引调整向导。

使用SQL查询优化工具和资源对于改进查询至关重要,通过这些工具可以了解查询的工作方式,找到问题并使用最佳实践来更快地获取数据并改善应用程序。

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

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

相关文章

【学生系统】基于结构体的一个训练小项目

(꒪ꇴ꒪ ),hello我是祐言博客主页:C语言基础,Linux基础,软件配置领域博主🌍快上🚘,一起学习!送给读者的一句鸡汤🤔:集中起来的意志可以击穿顽石!作者水平很有限,如果发现错误&#x…

Go []uint8和string的爱恨情仇

先上代码: package mainimport "fmt"func main() {byteSlice : []uint8{52, 44, 51} // 示例字节切片str : string(byteSlice)fmt.Printf("byteSlice:%v\r\n", str) }// 执行-输出 byteSlice:4,3 干货: 在Go语言中,[]u…

TiDB-学习笔记02

编写这个笔记,希望能记录下学习TiDB时候的知识点。 参考文章 目的链接&详细TiDB中文手册 Overview 面板重要监控指标详解 | PingCAP 文档中心 第二章 章节Overview 面板重要监控指标详解 | PingCAP 文档中心 认识Grafana Grafana监控TiDB 对应中文手册的【14…

如何使用 Java 代理插件在不更改应用程序代码的情况下捕获自定义指标

作者:Jack Shirazi Elastic APM Java 代理会自动跟踪许多指标,包括通过 Micrometer 或 OpenTelemetry Metrics API 生成的指标。 因此,如果你的应用程序(或其包含的库)已公开来自这些 API 之一的指标,则安装…

3Ds max无需插件创建逼真的草地

推荐: NSDT场景编辑器助你快速搭建可二次开发的3D应用场景 最终图像: 步骤-1 创建一个宽度 x 高度为 100100(我使用厘米)和 100100 段的平面。 步骤-2 将平面转换为“编辑多边形”并选择所有顶点(Ctrl A&#xff09…

AI Chat 设计模式:6. 装饰模式

本文是该系列的第六篇,内容采用问答式的方式展开,问题由我提出,答案由 Chat AI 作出,灰色背景的文字则主要是我的旁白。 问题列表 Q.1 你知道装饰模式吗A.1Q.2 详细说说装饰模式的组成角色A.2Q.3 举一个装饰模式的例子吧&#xf…

Threejs加载倾斜摄影OSGB数据

个人主页: 左本Web3D,更多案例预览请点击》 在线案例 个人简介:专注Web3D使用ThreeJS实现3D效果技巧和学习案例 💕 💕积跬步以至千里,致敬每个爱学习的你。获取模型或源码请点赞收藏加留言,有问…

数据库锁的12连问,抗住!

前言 金三银四很快就要来啦,准备了数据库锁的12连问,相信大家看完肯定会有帮助的。 1. 为什么需要加锁 在日常生活中,如果你心情不好想静静,不想被比别人打扰,你就可以把自己关进房间里,并且反锁。这就是生…

git基础教程(linux)

1.git简介 git 分布式版本控制 git两大特点: 版本控制:支持多人同时开发 分布式: 2.安装与配置 安装 sudo apt-get install git安装成功,运行如下命令: git3.创建一个版本库 (1)新建一个目录git_test&#xff0c…

网络编程7——IP协议(子网掩码,NAT机制,IPv6协议) + 以太网

文章目录 前言一、IP协议协议头格式认识IP地址格式组成子网掩码 地址管理1.动态分配2.NAT机制3.IPv6协议 路由选择 二、以太网以太网帧格式认识MTU 总结 前言 本人是一个普通程序猿!分享一点自己的见解,如果有错误的地方欢迎各位大佬莅临指导,如果你也对编程感兴趣的话&#x…

第十六章 原理篇:DETR

脑子不好使啊!复习过的东西过几天就忘记了! 参考教程: 论文地址:[pdf]End-to-End Object Detection with Transformer 源码地址:https://github.com/facebookresearch/detr 文章目录 概述the DETR modelDETR architect…

springboot篮球论坛系统

篮球论坛管理方面的任务繁琐,以至于每年都在篮球论坛管理这方面投入较多的精力却效果甚微,篮球论坛系统的目标就是为了能够缓解篮球论坛管理工作方面面临的压力,让篮球论坛管理方面的工作变得更加高效准确。 本项目在开发和设计过程中涉及到原理和技术有: B/S、java技术和MySQL…

Git❀详细使用教程

Git❀详细使用教程 一、Git简介1.1 什么是Git?1.2 Git的特点1.3 集中式与分布式的区别?1.4 Git工作流程图 二、Git安装与常用命令2.1 Git环境配置2.1.1 下载与安装2.1.2 基本配置2.1.3 为常用指令设置别名(可选)2.1.4 解决GitBash…

ChatGPT炒股:从上市公司招股说明书中批量提取发明专利表格

上市公司招股说明书通常会详细列明公司的发明专利,而通过企业的发明专利可以了解企业未来的业务布局情况,怎么把这些发明专利列表都批量提取出来呢? 随机打开几个上市公司的招股说明书,可以看到发明专利这一内容,共同的特征是都有…

Python的面向对象从入门到精通(简单易懂)

目录 1 初识对象 2. 成员方法 3. 类和对象 4. 构造方法 5. 其它内置方法 6. 封装 7. 继承 8. 复写 9. 类型的注解 10. 多态 1 初识对象 1. 生活中或是程序中,我们都可以使用设计表格、生产表格、填写表格的形式组织数据 2. 进行对比,在程序中&a…

进程间通信-无名管道

#include <stdio.h> #include <unistd.h> #include <sys/types.h> #include <string.h> int main(int argc, char **argv) {int pfd[2];int ret;pid_t pid;char buf[20]{0};retpipe(pfd);//创建一个无名管道if(ret<0){perror("pipe");ret…

lombok和guava工具

写在前面 本文看下如何通过使用lombok和guava来提高生产力。 1&#xff1a;lombok 我们开发程序时&#xff0c;如read method&#xff0c;write method&#xff0c;tostring&#xff0c;构造函数等&#xff0c;其写法其实都是固定和重复的&#xff0c;因此就可以考虑使用程序…

如何操作MySQL数据库基本数据

目录 一、MySQL数据库概念 数据 表&#xff08;数据表&#xff09; 数据库 数据库管理系统 数据库的建立和维护功能 数据定义功能 数据操纵功能 数据库的运行管理功能 通信功能 数据流向 二、主流数据库分类 1.SQL Server 数据库 &#xff08;微软分公司产品&…

Linux网络第六章——PXE高效批量网络装机

高效&#xff1a;速度快 批量&#xff1a;多台同时安装 网络&#xff1a;必须在网络环境 PXE&#xff1a;自动装机 需要&#xff1a; 1、DHCP实现地址自动分配 2、FTP把安装文件传输给客户机 3、xinetd&#xff1a;新一代的网络守护进程服务程序&#xff0c;管理轻量级…

赎金信(力扣)思维 JAVA

给你两个字符串&#xff1a;ransomNote 和 magazine &#xff0c;判断 ransomNote 能不能由 magazine 里面的字符构成。 如果可以&#xff0c;返回 true &#xff1b;否则返回 false 。 magazine 中的每个字符只能在 ransomNote 中使用一次。 示例 1&#xff1a; 输入&#xff…