技术文摘
实例教你如何优化 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 的执行效率,为应用程序的稳定运行提供有力支持。
- GitLab 支持 GitHub 以吸引其用户
- Serverless 风格微服务架构构建案例
- 初涉编程?这几款小工具助你效率翻倍
- MongoDB 助力实现高性能高可用双活应用架构的方法
- 程序猿避开线上 Bug 秘籍
- Facebook 两万亿天价罚款带来的启示
- Java 11 发布路线图:新特性展望
- 5 种以 Python 代码轻松达成数据可视化的途径
- 同为分布式缓存,Redis缘何更优
- 2018 年大数据 AI 发展趋势及平均年薪 35W 分析
- 实时视频通话超低延迟架构的探索与实践
- Kubernetes 在本地开发中的应用
- 程序员缺乏较强自学能力宜趁早转行
- 微服务化中持续集成:拆不易合更难的基石
- 张阜兴谈知乎:容器或为未来操作系统组成部分