当前位置: 首页 > news >正文

SQL 调优最佳实践笔记

定义与重要性

  • SQL 调优:提高SQL性能,减少查询时间和资源消耗。
  • 目标:减少查询时间和扫描的数据行数。

基本原则

  1. 减少扫描行数:只扫描所需数据。
  2. 使用合适索引:确保WHERE条件命中最优索引。
  3. 合适的Join类型:根据表的大小和关联性选择。
  4. 选择合适的数据库:根据业务类型选择OLTP或OLAP。

DQL最佳实践(SELECT)

  • 避免多表JOIN,尤其是大数据量情况下。
  • 避免全表扫描,使用索引优化查询。
索引使用
  1. 全表扫描问题:无索引或索引不合适。
  2. 索引创建:如CREATE INDEX idx_title ON books (title);
  3. 覆盖索引:包含查询所需所有列,减少回表查询。
  4. 主键点查:使用主键索引快速查询特定数据。

避免不必要的信息

  • 使用具体的列名代替SELECT *
  • 根据业务需求返回必要的列。

DML最佳实践(INSERT、UPDATE、DELETE)

  • 批量操作:使用单个SQL操作多行数据。
  • 删除数据
    • 使用WHERE条件指定删除范围。
    • 避免大批量删除,使用循环或限制条件。
    • 使用TRUNCATE代替DELETE清空表数据。

索引最佳实践

  1. 创建索引
    • 及时删除不需要的索引。
    • 考虑查询能否使用覆盖索引。
    • 选择过滤性好的列创建索引。
    • 组合索引时,将等值条件列放在前面。
  2. 使用索引
    • 确保索引在查询中被使用。
    • 遵循左前缀规则。
    • 避免使用!=NOT INLIKE '%...'等降低索引效率的条件。

总结

  • SQL调优是一个全面的优化过程,包括查询类SQL、索引优化等。
  • 针对不同的业务场景和数据库特性,采取相应的优化策略。
http://www.lryc.cn/news/427625.html

相关文章:

  • Eclipse的使用配置教程:必要设置、创建工程及可能遇到的问题(很详细,很全面,能解决90%的问题)
  • 遗传算法与深度学习实战(4)——遗传算法详解与实现
  • Nginx+Tomcat实现负载均衡、动静分离集群部署
  • 英语学习8月19日
  • 关于windows环境使用nginx的一些性能问题
  • “解决Windows电脑无法投影到其他屏幕的问题:尝试更新驱动程序或更换视频卡“
  • 第10章 无持久存储的文件系统 (2)
  • 云计算实训29——mysql主从复制同步、mysql5.7版本安装配置、python操作mysql数据库、mycat读写分离实现
  • AI搜索引擎Perplexica的本地部署(之二)Perplexica的非docker安装
  • Oracle环境下在相同参数和数据源的情况,mybatis-plus查询和sql查询结果不一致
  • springboot静态资源访问问题归纳
  • HTML与CSS学习Day01
  • Tina-Linux Bootloaer简述
  • 【Python】 Scrapyd:Python Web Scraping 的强大分布式调度工具
  • 吴恩达机器学习课后题-01线性回归
  • 白盒报告-jacoco
  • 【MySQL】SQL语句执行流程
  • Selenium自动化防爬技巧:从入门到精通,保障爬虫稳定运行,通过多种方式和add_argument参数设置来达到破解防爬的目的
  • 从数据类型到变量、作用域、执行上下文
  • 一文读懂:AI时代到底需要什么样的网络?
  • 基于HarmonyOS的宠物收养系统的设计与实现(一)
  • 严格模式报错
  • nginx: [emerg] the “ssl“ parameter requires ngx_http_ssl_module in nginx.conf
  • Docker 部署loki日志 用于微服务
  • [Day 57] 區塊鏈與人工智能的聯動應用:理論、技術與實踐
  • 06结构型设计模式——代理模式
  • 《深入浅出多模态》(九)多模态经典模型:MiniGPT-v2、MiniGPT5
  • 调试和优化大型深度学习模型 - 0 技术介绍
  • 华为S3700交换机配置VLAN的方法​
  • 学懂C++(三十八):深入详解C++网络编程:套接字(Socket)开发技术