在这里插入图片描述

文章目录

    • 1. 优化 SQL 语句
      • 避免全表扫描
      • 减少子查询,改用 JOIN
      • 避免 `SELECT `
    • 2. 合理使用索引
    • 3. 优化存储过程结构
      • 减少循环和临时变量
      • 避免重复计算
    • 4. 使用临时表和缓存
    • 5. 优化事务处理
    • 6. 分析和监控性能
    • 7. 优化数据库配置
    • 8. 避免用户自定义函数(UDF)
    • 9. 分批处理大数据量
    • 性能优化示例

1. 优化 SQL 语句

存储过程的性能往往取决于其中 SQL 语句的效率。

避免全表扫描

确保 WHERE 子句中的条件字段有索引,避免全表扫描:

-- 未优化:可能触发全表扫描
SELECT * FROM orders WHERE order_date > '2023-01-01';-- 优化:为 order_date 添加索引
CREATE INDEX idx_order_date ON orders (order_date);

减少子查询,改用 JOIN

子查询效率较低,尽量用 JOIN 替代:

-- 未优化:子查询
SELECT * FROM employees 
WHERE department_id IN (SELECT department_id FROM departments WHERE location = 'Beijing');-- 优化:JOIN
SELECT e.* FROM employees e
JOIN departments d ON e.department_id = d.department_id
WHERE d.location = 'Beijing';

避免 SELECT

只查询需要的字段,减少数据传输和内存开销:

-- 未优化
SELECT * FROM products;-- 优化
SELECT product_id, name, price FROM products;

2. 合理使用索引

  • 为经常用于 WHEREJOINORDER BY 的字段添加索引。
  • 避免过度索引,索引会增加写操作的开销。
  • 使用复合索引时,注意字段顺序(最左匹配原则)。
-- 为多条件查询创建复合索引
CREATE INDEX idx_customer_order ON orders (customer_id, order_date DESC);

3. 优化存储过程结构

减少循环和临时变量

循环(如 WHILEFOR)在存储过程中效率较低,尽量用集合操作替代:

-- 未优化:循环逐条更新
WHILE condition DOUPDATE products SET stock = stock - 1 WHERE product_id = id;
END WHILE;-- 优化:批量更新
UPDATE products SET stock = stock - 1 WHERE product_id IN (1, 2, 3, ...);

避免重复计算

将重复使用的计算结果存储在临时变量中:

-- 未优化:重复计算
IF (SELECT COUNT(*) FROM orders WHERE customer_id = 100) > 10 THEN-- 再次查询相同条件SELECT SUM(amount) FROM orders WHERE customer_id = 100;
END IF;-- 优化:使用临时变量
DECLARE order_count INT;
SELECT COUNT(*) INTO order_count FROM orders WHERE customer_id = 100;IF order_count > 10 THENSELECT SUM(amount) FROM orders WHERE customer_id = 100;
END IF;

4. 使用临时表和缓存

对于复杂查询,使用临时表存储中间结果,避免重复计算:

DELIMITER $$CREATE PROCEDURE GetSalesReport()
BEGIN-- 创建临时表存储中间结果CREATE TEMPORARY TABLE temp_sales (product_id INT,total_sales DECIMAL(10,2));-- 插入中间结果INSERT INTO temp_salesSELECT product_id, SUM(amount) FROM orders GROUP BY product_id;-- 使用临时表进行最终查询SELECT p.name, t.total_sales FROM products pJOIN temp_sales t ON p.product_id = t.product_id;-- 删除临时表DROP TEMPORARY TABLE IF EXISTS temp_sales;
END$$DELIMITER ;

5. 优化事务处理

  • 保持事务简短,减少锁持有时间。
  • 避免在事务中进行耗时操作(如文件读写、网络请求)。
DELIMITER $$CREATE PROCEDURE TransferFunds(IN from_account INT, IN to_account INT, IN amount DECIMAL(10,2))
BEGINSTART TRANSACTION;-- 快速执行更新操作UPDATE accounts SET balance = balance - amount WHERE account_id = from_account;UPDATE accounts SET balance = balance + amount WHERE account_id = to_account;COMMIT;
END$$DELIMITER ;

6. 分析和监控性能

  • 使用 EXPLAIN 分析 SQL 语句的执行计划,检查是否使用了索引:

    EXPLAIN SELECT * FROM orders WHERE customer_id = 100;
    
  • 使用 SHOW PROFILE 查看存储过程的详细执行时间:

    SET profiling = 1;
    CALL CalculateTotal(1001);
    SHOW PROFILES;
    SHOW PROFILE FOR QUERY 1;  -- 查询 ID 可从 SHOW PROFILES 结果中获取
    

7. 优化数据库配置

根据服务器硬件调整 MySQL 配置参数,例如:

  • innodb_buffer_pool_size:增大缓冲池大小,减少磁盘 I/O。
  • sort_buffer_size:调整排序缓冲区大小,优化排序操作。
  • max_connections:根据并发需求调整最大连接数。

8. 避免用户自定义函数(UDF)

用户自定义函数(尤其是用 Python 或 C 编写的外部 UDF)会显著降低性能,尽量用内置函数替代。

9. 分批处理大数据量

对于大数据集操作,分批处理以减少内存占用:

DELIMITER $$CREATE PROCEDURE ProcessLargeData()
BEGINDECLARE offset INT DEFAULT 0;DECLARE batch_size INT DEFAULT 1000;DECLARE total_rows INT;-- 获取总记录数SELECT COUNT(*) INTO total_rows FROM large_table;WHILE offset < total_rows DO-- 分批处理UPDATE large_table SET status = 'processed' WHERE id BETWEEN offset AND offset + batch_size;SET offset = offset + batch_size;END WHILE;
END$$DELIMITER ;

性能优化示例

假设有一个存储过程查询订单总金额,但性能较差:

DELIMITER $$CREATE PROCEDURE GetOrderTotal(IN customerId INT)
BEGIN-- 未优化:全表扫描 + 子查询SELECT customer_id,(SELECT COUNT(*) FROM orders WHERE customer_id = c.customer_id) AS order_count,(SELECT SUM(amount) FROM orders WHERE customer_id = c.customer_id) AS total_amountFROM customers cWHERE c.customer_id = customerId;
END$$DELIMITER ;

优化后:

DELIMITER $$CREATE PROCEDURE GetOrderTotal(IN customerId INT)
BEGIN-- 优化:JOIN + 索引 + 聚合函数SELECT c.customer_id,COUNT(o.order_id) AS order_count,SUM(o.amount) AS total_amountFROM customers cLEFT JOIN orders o ON c.customer_id = o.customer_idWHERE c.customer_id = customerIdGROUP BY c.customer_id;
END$$DELIMITER ;

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

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

相关文章

尚硅谷redis7 47-48 redis事务之理论简介

47 redis事务之理论简介 什么是事务 可以一次执行多个命令,本质是一组命令的集合。一个事务中的所有命令都会序列化,按顺序地串行化执行而不会被其它命令插入 能干什么&#xff1f; 一个队列中&#xff0c;一次性、顺序性、排他性的执行一系列操作 redis事务vs数据库事务 …

Nginx 在四大核心场景中的应用实践与优化

一、Nginx 核心应用场景深度解析 1. HTTP 服务器&#xff1a;静态资源的高性能承载者 Nginx 作为 HTTP 服务器时&#xff0c;凭借轻量级架构和高效的事件驱动模型&#xff0c;成为静态资源服务的首选方案。 核心能力与场景 静态文件高效处理&#xff1a;直接响应 HTML、CSS…

亚当·斯密思想精髓的数学建模与形式化表征

亚当斯密思想精髓的数学建模与形式化表征 摘要&#xff1a;本文运用数学建模方法对亚当斯密的经济与伦理思想进行形式化表征。通过分工的规模经济模型和市场均衡条件展现《国富论》中"看不见的手"原理&#xff1b;采用扩展效用函数与合作博弈均衡解释《道德情操论》…

FastDFS集群部署与性能优化实战

目录 一、介绍 二、FastDFS原理 三、FastDFS部署 1.资源清单 2.修改主机名 3.安装libfastcommon&#xff08;tracker01、tracker02、storage1、storage2&#xff09; 4.安装编译FastDFS&#xff08;tracker01、tracker02、storage1、storage2&#xff09; 5.配置tracker…

学习心得(14--16)

模板&#xff1a; 前端的页面单独存在模板当中 jinja2 &#xff1a;模板语法 保持前端页面不变的情况下&#xff0c;返回内容给前端做法&#xff1a; 写一个data&#xff0c;并在return中的render_template中&#xff0c;写上datadata 使用时&#xff0c;要将templa…

stm与51单片机哪个更适合新手学

一句话总结 51单片机&#xff1a;像学骑自行车&#xff0c;简单便宜&#xff0c;但只能在小路上骑。 STM32&#xff1a;像学开汽车&#xff0c;复杂但功能强&#xff0c;能上高速公路&#xff0c;还能拉货载人&#xff08;做复杂项目&#xff09;。 1. 为啥有人说“先学51单片…

Web安全测试-文件上传绕过-DVWA

Web安全测试-文件上传绕过-DVWA 很多网站都有上传资源(图片或者文件)的功能&#xff0c;资源上传后一般会存储在服务器的一个文件夹里面&#xff0c;如果攻击者绕过了上传时候的文件类型验证&#xff0c;传了木马或者其他可执行的代码上去&#xff0c;那服务器就危险了。 我用…

ant-design-vue中的分页组件自定义

ant-design-vue中的分页组件自定义 实现效果 实现代码 需要自己创建一个分页组件的代码然后导入进去。 <template><div style"display: flex; justify-content: space-between; margin-bottom: 10px"><div><a-select v-model:value"pageS…

LabVIEW软件开发过程中如何保证软件的质量?

一、需求与架构设计阶段 明确功能边界与技术指标 在测试系统设计初期&#xff0c;围绕比例阀性能测试核心需求&#xff08;如压力 / 流量信号采集、特性曲线绘制、数据对比分析&#xff09;&#xff0c;定义软件功能模块&#xff08;数据采集、逻辑控制、界面显示&#xff09;&…

Linux 527 重定向 2>1 rsync定时同步(未完)

rsync定时同步 配环境 关闭防火墙、selinux systemctl stop firewalld systemctl disable firewalld setenforce0 vim /etc/SELINUX/config SELINUXdisable515 设置主机名 systemctl set-hostname code systemctl set-hostname backup 配静态ip rsync 需要稳定的路由表和端…

Vue 3.0 中状态管理Vuex 与 Pinia 的区别

在 Vue.js 应用开发中&#xff0c;状态管理是构建复杂应用的关键环节。随着 Vue 3 的普及和 Composition API 的引入&#xff0c;开发者面临着状态管理库的选择问题&#xff1a;是继续使用经典的 Vuex&#xff0c;还是转向新兴的 Pinia&#xff1f;本文将从设计理念、API 设计、…

分布式缓存:三万字详解Redis

文章目录 缓存全景图PreRedis 整体认知框架一、Redis 简介二、核心特性三、性能模型四、持久化详解五、复制与高可用六、集群与分片方案 Redis 核心数据类型概述1. String2. List3. Set4. Sorted Set&#xff08;有序集合&#xff09;5. Hash6. Bitmap7. Geo8. HyperLogLog Red…

React useEffect和useEffectLa

原理把对象以树的形式存档&#xff0c;根据URL进行匹配渲染对应组件 useEffect 和useLayoutEffect区别 useEffect中的回调函数放在异步任务队列中&#xff0c;是异步的&#xff0c;会在React渲染&#xff0c; dom 元素更新&#xff0c;浏览器绘制完成之后才会执行 useLayout…

multiprocessing多进程使用案例

multiprocessing — 基于进程的并行&#xff1a;https://docs.python.org/zh-cn/3.11/library/multiprocessing.html import sys from fastchat.serve.controller import Controller from fastchat.serve.model_worker import ModelWorker from fastchat.serve.openai_api_ser…

鸿蒙OSUniApp 开发实时天气查询应用 —— 鸿蒙生态下的跨端实践#三方框架 #Uniapp

使用 UniApp 开发实时天气查询应用 —— 鸿蒙生态下的跨端实践 在移动互联网时代&#xff0c;天气应用几乎是每个人手机中的"标配"。无论是出行、旅游还是日常生活&#xff0c;实时获取天气信息都极为重要。本文将以"实时天气查询应用"为例&#xff0c;详…

蓝桥杯178 全球变暖

题目描述 你有一张某海域 NxN 像素的照片&#xff0c;"."表示海洋、"#"表示陆地&#xff0c;如下所示&#xff1a; ....... .##.... .##.... ....##. ..####. ...###. ....... 其中"上下左右"四个方向上连在一起的一片陆地组成一座岛屿。例如上…

第五十二节:增强现实基础-简单 AR 应用实现

引言 增强现实(Augmented Reality, AR)是一种将虚拟信息叠加到真实世界的技术,广泛应用于游戏、教育、工业维护等领域。与传统虚拟现实(VR)不同,AR强调虚实结合,用户无需完全沉浸到虚拟环境中。本文将通过Python和OpenCV库,从零开始实现一个基础的AR应用:在检测到特定…

青少年编程与数学 02-019 Rust 编程基础 23课题、web服务器

青少年编程与数学 02-019 Rust 编程基础 23课题、web服务器 一、单线程Web 服务器基本实现步骤完整代码示例运行结果项目结构注意事项扩展方向 二、多线程Web服务器1. 基本架构设计2. 完整实现代码项目文件结构文件内容Cargo.tomlsrc/main.rssrc/lib.rsstatic/hello.htmlstatic…

(14)JVM弹性内存管理

文章目录 &#x1f680; JVM弹性内存管理&#xff1a;K8s环境下的内存优化终极攻略⚡ TL;DR&#x1f635; 等等&#xff0c;为什么我需要关心这个&#xff1f;&#x1f6e0;️ 五步搞定弹性内存&#xff08;拯救你的Java应用&#xff09;1️⃣ JVM参数调教2️⃣ 监控指标全覆盖…

Spring Boot集成Spring AI与Milvus实现智能问答系统

在Spring Boot中集成Spring AI与Milvus实现智能问答系统 引言 随着人工智能技术的快速发展&#xff0c;智能问答系统在企业中的应用越来越广泛。然而&#xff0c;传统的问答系统往往面临AI幻觉&#xff08;Hallucination&#xff09;问题&#xff0c;即生成不准确或无意义的回…