技术文摘
实例教你如何优化 SQL
2025-01-15 01:25:04 小编
在数据库管理与开发中,优化 SQL 至关重要,它能显著提升系统性能,减少资源消耗。下面通过实例为大家讲解如何优化 SQL。
假设有一个电商数据库,其中有一张商品表 products,包含字段 product_id、product_name、price、category_id 等,还有一张分类表 categories,包含 category_id 和 category_name 字段。现在要查询每个分类下价格最高的商品信息。
原始的 SQL 语句可能是这样:
SELECT p.product_id, p.product_name, p.price, p.category_id, c.category_name
FROM products p
JOIN categories c ON p.category_id = c.category_id
WHERE (p.category_id, p.price) IN (
SELECT category_id, MAX(price)
FROM products
GROUP BY category_id
);
这种写法虽然能得到结果,但效率较低。因为子查询会对整个 products 表进行全表扫描,然后再与主查询进行关联。
优化后的 SQL 可以使用窗口函数:
WITH RankedProducts AS (
SELECT p.product_id, p.product_name, p.price, p.category_id, c.category_name,
ROW_NUMBER() OVER (PARTITION BY p.category_id ORDER BY p.price DESC) AS rn
FROM products p
JOIN categories c ON p.category_id = c.category_id
)
SELECT product_id, product_name, price, category_id, category_name
FROM RankedProducts
WHERE rn = 1;
这里通过窗口函数 ROW_NUMBER() 为每个分类下的商品按价格从高到低排序,并赋予一个行号 rn。然后在外部查询中只选择 rn 为 1 的记录,即每个分类下价格最高的商品。
另一个常见的优化点是索引的使用。如果在 products 表的 category_id 和 price 字段上创建联合索引:
CREATE INDEX idx_category_price ON products (category_id, price);
这样在执行上述查询时,数据库可以利用索引快速定位到所需数据,大大提高查询速度。
优化 SQL 需要从查询逻辑和索引使用等多方面入手。通过合理运用窗口函数、避免全表扫描,以及正确创建和使用索引,能够有效提升 SQL 的执行效率,为应用程序的稳定运行提供有力支持。
- Vue 中 “this is undefined” 问题的修复方法
- 全栈开发中程序员必知的 19 个框架和库
- Jupyter Notebooks 在 VS 代码中的基础入门开发教程
- 上次 24 个实用 ES6 方法获赞,此次再添 10 个
- 百度工程师因获利 10 万判刑 3 年
- Dashboard 的 10 个实现原则浅析
- JavaScript 中的错误对象有哪些类型,你知道吗?
- 7 个提升效率的 JavaScript 实用函数
- 7 种高效的 Python 编程技法
- Julia 与 Python 之比较:有人给出 5 个 Julia 更优理由
- 利用阿里开源工具排查线上 CPU 居高问题的方法一文知晓
- 如何解决团队协作效率低下 阿里的做法
- 曾经苦学的技术如今已无用武之地
- 全新版任你发,我选 Java 8 !
- Python 异步和 JavaScript 原生异步的差异在哪?