news 2026/6/15 17:41:31

性能测试:数据库的 SQL 性能优化实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
性能测试:数据库的 SQL 性能优化实战

做过性能测试的同学都应该知道,性能测试核心就是结果分析和性能瓶颈调优,然后性能的瓶颈70%-80%的问题都是来自于数据库。所以,掌握数据库的瓶颈分析对其性能测试工程师来说尤为重要。

数据库的性能优化

数据库的性能优化可以从硬件和软件两个层面来考虑:

1)硬件方面:主要就是磁盘选择,考虑磁盘的读写速度、消耗IO【读入 写出】性能,所以尽量选择固态硬盘【速度比机械硬盘高但是价格贵】,并使用独立服务器,跟业务服务器分开。

数据库服务器的存储操作大于计算操作,所以关注磁盘会更多一些;

但是CPU的影响也会有,比如sql复杂一些的时候也会消耗CPU;所以同步关注CPU;

硬件的优化因为主要涉及设备配件的选型和购买,所以性能测试能做的性能优化有限;

2)软件方面:我们做数据库的性能优化主要是这个层面的优化, 数据库层面优化 + 表层面优化

库层面:MYSQL数据库的配置参数会影响数据库的一些性能,比如最大连接数;

表层面:主要是索引字段的设置优化和SQL的优化。

我们这篇文章主要讲一下表层面的SQL性能优化。

SQL语句性能优化

数据库SQL性能优化是提升数据库运行效率的关键环节,以下是一些具体的注意点,并结合案例进行演示和说明,帮助大家理解。

1、避免使用SELECT *

使用SELECT *会检索表中的所有列,会导致不必要的数据传输和内存消耗;如果数据库和项目是两台独立的服务器的话,还会增加网络传输的负载。所以尽量查询具体的列:

比如SQL样例:

* --优化前:select * from user where id=1; * --优化后:select name,age from user where id =1;

2. 使用JOIN代替子查询

子查询通常会导致数据库执行多次表扫描,会增加I/O开销和查询执行时间;使用JOIN操作将多个查询合并为一个查询,可以更好地利用索引和减少表扫描次数;

比如SQL样例:

-- 优化前(子查询) SELECT * FROM orders WHERE user_id = (SELECT user_id FROM users WHERE username = 'john_doe'); -- 优化后(JOIN) SELECT o.* FROM orders o JOIN users u ON o.user_id = u.user_id WHERE u.username = 'john_doe';

3. 避免使用OR,使用UNION或UNION ALL代替

在WHERE子句中使用OR条件可能会导致数据库无法使用索引,从而增加全表扫描的机会。使用UNION ALL将多个查询结果合并,每个查询都可以单独使用索引进行优化,从而减少全表扫描的机会。

比如SQL样例:

* -- 优化前(使用OR):SELECT * FROM users WHERE age > 30 OR city = 'New York'; * -- 优化后(使用UNION ALL) SELECT * FROM users WHERE age > 30 UNION ALL SELECT * FROM users WHERE city = 'New York';

注意:使用UNION ALL时,需要确保结果集中不包含重复数据,或者重复数据对业务逻辑没有影响。

4. 避免在WHERE子句中使用函数

在WHERE子句中使用函数会导致数据库无法使用索引来加速查询。将函数计算移到列外,直接使用列值进行判断,这样数据库可以利用索引来加速查询,避免全表扫描。

比如SQL样例:

-- 优化前(使用函数) SELECT * FROM users WHERE SUBSTRING(username, 1, 3) = 'joh'; -- 优化后(不使用函数) SELECT * FROM users WHERE username LIKE 'joh%';

5、使用LIMIT限制结果集大小

如果查询返回的结果集过大,会消耗大量的内存和I/O资源。使用LIMIT语句限制结果集的大小可以减少数据库的负担,并提高查询性能。

比如SQL样例:

– 优化前(无LIMIT) SELECT id,name FROM products;

– 优化后(使用LIMIT) SELECT id,name FROM products LIMIT 100;

6、选择合理的字段类型

字段类型选择不当会导致数据存储效率低下和查询性能下降。例如,使用VARCHAR类型存储数字数据会浪费存储空间,并降低查询速度。

所以,根据业务需求选择最合适的字段类型。例如,对于数字数据,应使用INT、FLOAT或DECIMAL等数字类型;对于文本数据,应使用VARCHAR或TEXT等字符串类型。这样可以提高存储效率和查询性能。

SQL案例:使用数字类型代替字符串类型(如果适用)

– 优化前(使用VARCHAR):CREATE TABLE example (id VARCHAR(10), value VARCHAR(100));

– 优化后(使用INT):CREATE TABLE example (id INT, value VARCHAR(100));

7、使用索引

索引是提高SQL查询性能的关键。没有索引的表在查询时需要执行全表扫描来查找数据,这会导致查询性能下降。在常用的查询条件和连接条件的列上建立索引。索引可以加快查询速度,并减少全表扫描的机会。同时,要注意索引的维护成本,避免创建过多的索引导致插入、更新和删除操作的性能下降。

例如SQL语句:

– 在user_id列上创建索引 CREATE INDEX idx_user_id ON users(user_id);

– 使用索引进行查询 SELECT * FROM users WHERE user_id = 123;

8、避免全表扫描

优化方式:通过合理的索引设计和查询条件,避免全表扫描。

– 避免在没有索引的列上进行范围查询

– 优化前(可能导致全表扫描):SELECT * FROM products WHERE price > 100;

– 优化后(在price列上创建索引):CREATE INDEX idx_price ON products(price);

SELECT * FROM products WHERE price > 100;

总结

所以,在做性能测试的时候,如果发现数据库占的CPU比较高,或者响应时间比较长,都可以去检查一下 数据库是否存在上述的SQL问题,从而来优化项目的数据库的性能。

感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 14:47:22

LED显示屏安装模块定位结构:精确对位操作指南

以下是对您提供的技术博文进行深度润色与结构重构后的专业级技术文章。全文已彻底去除AI生成痕迹,摒弃模板化标题与空泛表述,以一位深耕LED显示系统集成十余年、亲手调试过数百块P0.9以上小间距屏的工程师口吻重写——语言精准、逻辑严密、经验厚重&…

作者头像 李华
网站建设 2026/6/15 13:52:52

Z-Image-Turbo金融插画案例:自动化视觉内容生成部署教程

Z-Image-Turbo金融插画案例:自动化视觉内容生成部署教程 1. 引言:为什么金融场景需要AI插画? 在金融行业,视觉内容的制作长期面临“高要求、低效率”的矛盾。一份投资报告需要配图展示经济趋势,一个理财产品上线需要…

作者头像 李华
网站建设 2026/6/15 15:23:37

企业级应用首选!gpt-oss-20b-WEBUI保障数据安全

企业级应用首选!gpt-oss-20b-WEBUI保障数据安全 在金融风控会议中审阅千页信贷报告、在政务内网中起草涉密政策文件、于医疗专网中解析患者病历并生成结构化摘要——这些场景有一个共同前提:模型必须运行在完全隔离的本地环境中,输入输出全程…

作者头像 李华
网站建设 2026/6/15 14:12:51

【Oracle】 RAC 数据库监听原理解析

Oracle RAC(Real Application Clusters)的监听体系是实现集群高可用、负载均衡和故障转移的核心组件,其设计逻辑围绕 “分布式节点协同 统一客户端接入” 展开。以下从核心原理、组件交互、注册机制、连接流程四个维度进行深度解析&#xff…

作者头像 李华
网站建设 2026/6/15 15:23:21

Unsloth训练日志分析:关键指标解读指南

Unsloth训练日志分析:关键指标解读指南 1. Unsloth 简介 用Unsloth训练你自己的模型,Unsloth是一个开源的LLM微调和强化学习框架。 在Unsloth,我们的使命是让人工智能尽可能准确且易于获取。训练并部署DeepSeek、gpt-oss、Llama、TTS、Qwe…

作者头像 李华