SQL性能优化策略

发现问题
  • 通过业务监控发现慢SQL或接口响应延迟。
  • 利用性能分析工具定位问题。
定位SQL语句
  • 使用监控工具确定影响性能的SQL语句和表。
SQL查询变慢原因
  1. 索引失效:查询未使用索引或索引效率低。
  2. 多表连接:JOIN操作导致性能下降。
  3. 查询字段过多:使用SELECT *返回不必要字段。
  4. 数据量过大:单表数据量超1000万条。
  5. 索引基数太小:字段值分布不均,索引效率低。
  6. 数据库连接不足:业务量大或慢SQL占用连接。
  7. 表结构不合理:字段过长或缺乏冗余。
  8. 数据库IO或CPU负载高:资源不足影响查询速度。
  9. 长事务:事务占用连接资源。
  10. 锁竞争:并发请求争夺资源。
  11. 数据库参数设置不合理:内存、缓存、线程池配置不当。
索引失效优化
  • 分析执行计划,优化索引设计或SQL语句。
  • 避免通配符LIKE和字段函数操作。
  • 强制指定索引或优化查询条件。
特殊情况:Explain执行计划分析
  • type=index可能意味着全索引扫描,并非有效索引使用。
  • 调整查询或索引以解决。
多表JOIN优化
  • 优化查询条件,使用有效连接字段索引。
  • 限制返回字段数量。
  • 考虑表大小和结构,使用适当连接类型。
索引基数问题
  • 避免对基数低的字段建立索引。
查询字段过多优化
  • 避免使用SELECT *,只查询必要字段。
  • 垂直分表减少单表数据量。
数据量过大解决方案
  • 数据归档:移出历史数据。
  • 分库分表、分区:分散数据存储。
  • 使用第三方数据库:如OceanBase、TiDB、Elasticsearch。
数据库连接数不足
  • 分析原因,如业务量大或慢SQL。
  • 使用缓存、异步更新、拆分存储或合并更新请求。
表结构不合理
  • 重构数据库或考虑分表。
数据库IO或CPU高负载
  • 分析原因,调整资源配置。
长事务
  • 优化事务处理,避免长时间占用连接。
锁竞争
  • 优化并发控制,减少锁等待。
数据库参数设置
  • 调整内存、缓存、线程池大小等参数。

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

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

相关文章

Monitor结构解读之EntryQ和WaitSet的区别

EntryQ(或_EntryList)和WaitSet(或_WaitSet)在Java的monitor机制中扮演着不同的角色,它们之间的主要区别体现在以下几个方面: 1. 等待原因和机制 EntryQ(或_EntryList)&#xff1a…

面试常考题---128陷阱(详细)

1.问题引入 分别引入了int和Integer变量,并进行比较 int b 128; int b1 128;Integer d 127; Integer d1 127;Integer e 128; Integer e1 128;System.out.println(bb1); System.out.println(dd1); System.out.println(ee1); System.out.println(e.equals(e1)…

刷题(day01)

1、leetcode485.最大连续1的个数 给定一个二进制数组 nums , 计算其中最大连续 1 的个数。 示例 1: 输入:nums [1,1,0,1,1,1] 输出:3 解释:开头的两位和最后的三位都是连续 1 ,所以最大连续 1 的个数是 3.…

Nginx 高效加速策略:动静分离与缓存详解

在现代Web开发中,网站性能是衡量用户体验的关键指标之一。Nginx,以其出色的性能和灵活性,成为众多网站架构中不可或缺的一部分。本文将深度解析如何利用Nginx实现动静分离与缓存,从而大幅提升网站加载速度和响应效率。 理解动静分…

昇思第18天打卡|ShuffleNet图像分类

ShuffleNet网络介绍 ShuffleNetV1是旷视科技提出的一种计算高效的CNN模型,和MobileNet, SqueezeNet等一样主要应用在移动端,所以模型的设计目标就是利用有限的计算资源来达到最好的模型精度。ShuffleNetV1的设计核心是引入了两种操作:Pointw…

张大哥笔记:你一旦开窍,就会发现遍地都是钱

大家有没有发现,穷人总是追逐眼前的利益,总是在追着钱跑,却总是赚不到钱。而富人有着长远的见识,追着问题跑,最后却赚的盆满钵满。 我们听过这样一句话,钱不是赚来的,而是帮助别人解决问题后给你…

【计算机】同步/异步

同步/异步 在计算机科学和编程中,“同步”(Synchronization)是一种机制,用于协调不同进程或线程之间的操作,以避免竞态条件(race conditions)、死锁(deadlocks)和其他并…

Qt/C++编写地图应用/离线地图下载/路径规划/轨迹回放/海量点/坐标转换

一、前言说明 这个地图组件写了很多年了,最初设计的比较粗糙,最开始只是为了满足项目需要,并没有考虑太多拓展性,比如最初都是按照百度地图写死在代码中,经过这几年大量的现场实际应用,以及大量的用户提出…

Django 新增数据 save()方法

1,添加模型 Test/app11/models.py from django.db import modelsclass Book(models.Model):title models.CharField(max_length100)author models.CharField(max_length100)publication_date models.DateField()price models.DecimalField(max_digits5, decim…

BFC 是什么?

BFC 是块级格式化上下文(Block Formatting Context)的缩写,是 CSS 中一个重要的概念,用于控制块级盒子的布局及浮动元素的交互。BFC 是一个独立的渲染区域,内部的块级盒子会按照特定的规则进行布局,不会影响…

软件工程(上)

目录 软件过程模型(软件开发模型) 瀑布模型 原型模型 V模型 构件组装模型 螺旋模型(原型瀑布) 基于构件的软件工程(CBSE) 快速应用开发模型(RAD) 统一过程(UP&a…

Linux学习看这一篇就够了,超超超牛的Linux基础入门

引言 小伙伴们,不管是学习c还是学习其他语言在我们学的路上都绕不过操作系统,而且,老生常谈的Linux更是每个计算机人的必修,那么我们对Linux的了解可能只是从别人那听到的简单的这个系统很牛,巴拉巴拉的,但…

大模型日报 2024-07-08

大模型日报 2024-07-08 大模型资讯 Anthropic CEO:大模型训练成本暴涨,2027年将达1000亿美元! Anthropic首席执行官表示,当前AI模型训练成本是10亿美元,未来三年,这个数字可能会上升到100亿美元甚至1000亿美…

GitLab管理员常用配置及设置汇总

​ 之前在 虚拟机Ubuntu 22.04上搭建GitLab操作步骤 上介绍了在Ubuntu 22.04上如何搭建社区版的GitLab,这里整理下作为GitLab管理员时在搭建完GitLab CE后,如何对其进行配置或设置 更改仓库存储位置:切换到root用户下操作 默认存放位置&…

SSL 证书

自动获取 Lets Encrypt 免费证书 (适用于 Linux 系统) 安装 Certbot sudo apt-get update sudo apt-get install certbot python3-certbot-nginx # Nginx 服务器 sudo apt-get install certbot python3-certbot-apache # Apache 服务器 获取和安装证…

小米rdemi红米ax3000t刷机 20240707最新配套完整程序整理合集

小米rdemi红米ax3000t刷机程序地址: https://www.123pan.com/s/LA1bVv-EOzVv.html 小米路由器SSH密码计算器 https://www.1234f.com/fuwu/ax3000t/ 最新更新地址:https://www.1234f.com/fuwu/openwrt/ 依次输入如下命令: curl -X POST h…

Leetcode 295.数据流的中位数

295.数据流的中位数 问题描述 中位数是有序整数列表中的中间值。如果列表的大小是偶数,则没有中间值,中位数是两个中间值的平均值。 例如 arr [2,3,4] 的中位数是 3 。例如 arr [2,3] 的中位数是 (2 3) / 2 2.5 。 实现 MedianFinder 类: Media…

算法013:水果成篮

水果成篮. - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/fruit-into-baskets/ 这道题题目很长,仔细阅读过后,我们其实可以简化成&#xff…

MySQL 9.0新特性:向量存储

MySQL 9.0 正式版已经发布,其中一个亮点就是向量(VECTOR)数据类型的支持,本文给大家详细介绍一下这个新功能。 向量类型 MySQL 9.0 增加了一个新的向量数据类型:VECTOR。它是一种可以存储 N 个数据项的数据结构&…