亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL中慢查詢優(yōu)化的技術(shù)指南

 更新時間:2025年06月24日 09:12:00   作者:拾荒的小海螺  
后端開發(fā)中,數(shù)據(jù)庫是系統(tǒng)性能瓶頸的高發(fā)地帶,而慢查詢往往是系統(tǒng)響應(yīng)遲緩的罪魁禍?zhǔn)?本文將全面梳理慢SQL的優(yōu)化思路,感興趣的小伙伴可以了解下

1、簡述

在 Java 后端開發(fā)中,數(shù)據(jù)庫是系統(tǒng)性能瓶頸的高發(fā)地帶,而 慢 SQL 查詢 往往是系統(tǒng)響應(yīng)遲緩的“罪魁禍?zhǔn)?rdquo;。本文將全面梳理慢 SQL 的優(yōu)化思路,并結(jié)合 Java 示例進行實戰(zhàn)演練。

2、慢查詢的常見表現(xiàn)

慢查詢通常表現(xiàn)為:

  • 接口響應(yīng)時間緩慢
  • 數(shù)據(jù)庫 CPU 占用高
  • 表鎖、死鎖頻繁
  • Java 應(yīng)用線程池阻塞嚴(yán)重

慢 SQL 的主要成因

成因類型說明
未使用索引全表掃描,查詢耗時
使用了低效的函數(shù)或表達式如 LIKE '%xx%', DATE()
多表關(guān)聯(lián)不當(dāng)join 條件缺失或不走索引
過多返回字段只用到了部分字段卻 SELECT *
where 條件不精準(zhǔn)無法過濾大量無關(guān)數(shù)據(jù)
數(shù)據(jù)庫設(shè)計不合理字段冗余、缺乏范式、字段類型錯誤等

3、慢查詢優(yōu)化的通用思路

加索引(重點)

為 WHERE、JOIN、ORDER BY、GROUP BY 中涉及的字段加索引

避免使用函數(shù)包裹字段,如 LEFT(name, 3),會導(dǎo)致無法使用索引

使用 EXPLAIN 分析執(zhí)行計劃

EXPLAIN SELECT * FROM orders WHERE user_id = 100;

關(guān)注字段:

字段說明
type連接類型(越接近 const 越好)
rows掃描行數(shù)(越小越好)
key使用的索引名稱
Extra是否使用臨時表、排序等

分頁優(yōu)化

避免深度分頁:

-- 慢查詢(跳過大量行)
SELECT * FROM orders LIMIT 1000000, 20;

-- 推薦(使用上次主鍵記錄)
SELECT * FROM orders WHERE id > 1000000 LIMIT 20;

拆表分區(qū)

垂直拆分:將大表按字段拆分為多個表

水平分表:按業(yè)務(wù)字段分庫分表(如 user_id 分表)

分區(qū)表:MySQL 原生支持(適合歷史歸檔數(shù)據(jù))

減少嵌套子查詢

使用 JOIN 或臨時表替代子查詢,更高效。

SQL 只查需要的字段

-- 慎用
SELECT * FROM user;

-- 推薦
SELECT id, name, email FROM user;

4、慢 SQL 實踐排查與優(yōu)化

示例:慢查詢前后對比

原始 SQL(慢)

SELECT * FROM orders WHERE DATE(create_time) = '2024-01-01';

問題:

  • 使用了 DATE() 函數(shù),索引失效
  • 全表掃描,耗時嚴(yán)重

優(yōu)化 SQL(快)

SELECT * FROM orders 
WHERE create_time >= '2024-01-01 00:00:00' 
  AND create_time < '2024-01-02 00:00:00';

優(yōu)點:

  • 范圍查詢走索引
  • 支持時間范圍過濾

Java 中日志配置監(jiān)控慢 SQL

# application.yml 示例(Spring Boot)
logging:
  level:
    com.zaxxer.hikari.HikariConfig: DEBUG
    com.zaxxer.hikari: TRACE
spring:
  datasource:
    url: jdbc:mysql://localhost:3306/demo
    username: root
    password: root
    hikari:
      maximum-pool-size: 10
      connection-timeout: 3000

使用工具(如 p6spy)打印 SQL 及耗時,或開啟 MySQL 慢查詢?nèi)罩荆?/p>

-- MySQL 開啟慢查詢?nèi)罩?
SET GLOBAL slow_query_log = 'ON';
SET GLOBAL long_query_time = 1; -- 超過 1 秒記錄

SQL 優(yōu)化 checklist

  • 是否使用了合適的索引
  • 是否避免了函數(shù)、表達式阻礙索引
  • 是否使用了 EXPLAIN 檢查執(zhí)行計劃
  • 是否合理分頁、避免深度翻頁
  • 是否控制了查詢字段數(shù)量
  • 是否考慮拆分大表或分區(qū)表
  • 是否避免了嵌套子查詢

5、SQL 優(yōu)化實戰(zhàn)樣例

場景 1:模糊查詢優(yōu)化

-- 慢:前置通配符無法使用索引
SELECT * FROM user WHERE name LIKE '%abc%';

-- 優(yōu)化:使用全文索引或右模糊匹配
SELECT * FROM user WHERE name LIKE 'abc%';

場景 2:避免函數(shù)阻礙索引

-- 慢
SELECT * FROM orders WHERE YEAR(create_time) = 2024;

-- 快
SELECT * FROM orders 
WHERE create_time >= '2024-01-01' 
  AND create_time < '2025-01-01';

場景 3:多字段組合索引使用順序

-- 有聯(lián)合索引 (user_id, status)

-- 推薦:user_id 和 status 都參與
SELECT * FROM orders WHERE user_id = 100 AND status = 'PAID';

-- 不推薦:只用 status,索引無法生效
SELECT * FROM orders WHERE status = 'PAID';

6、結(jié)語

慢查詢是系統(tǒng)性能優(yōu)化的重要戰(zhàn)場。對于 Java 開發(fā)者而言,理解 SQL 執(zhí)行機制和優(yōu)化原則,比“用緩存”更根本、更有效。

日常開發(fā)中,應(yīng)做到:

  • 編寫 SQL 前先考慮是否能走索引
  • 查詢慢時第一時間用 EXPLAIN 排查
  • 數(shù)據(jù)庫設(shè)計時就考慮查詢結(jié)構(gòu)

到此這篇關(guān)于MySQL中慢查詢優(yōu)化的技術(shù)指南的文章就介紹到這了,更多相關(guān)MySQL慢查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL中常用查看鎖和事務(wù)的SQL語句詳解

    MySQL中常用查看鎖和事務(wù)的SQL語句詳解

    這篇文章主要介紹了MySQL中常用查看鎖和事務(wù)的SQL語句,用于查看鎖和事務(wù)的狀態(tài),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • mysql存儲過程中使用游標(biāo)的實例

    mysql存儲過程中使用游標(biāo)的實例

    使用MYSQL存儲過程,可以實現(xiàn)諸多的功能,下面將為您介紹一個MYSQL存儲過程中使用游標(biāo)的實例
    2014-01-01
  • 防止web項目中的SQL注入

    防止web項目中的SQL注入

    這篇文章介紹了防止web項目中的SQL注入,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。需要的朋友可以收藏下,方便下次瀏覽觀看
    2021-12-12
  • 抽取oracle數(shù)據(jù)到mysql數(shù)據(jù)庫的實現(xiàn)過程

    抽取oracle數(shù)據(jù)到mysql數(shù)據(jù)庫的實現(xiàn)過程

    今天小編就為大家分享一篇關(guān)于抽取oracle數(shù)據(jù)到mysql數(shù)據(jù)庫的實現(xiàn)過程,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • mysql安裝圖解 mysql圖文安裝教程(詳細(xì)說明)

    mysql安裝圖解 mysql圖文安裝教程(詳細(xì)說明)

    很多朋友剛開始接觸mysql數(shù)據(jù)庫服務(wù)器,下面是網(wǎng)友整理的一篇mysql的安裝教程,步驟明細(xì)也有詳細(xì)的說明。
    2010-06-06
  • 查看MySQL是否處于運行狀態(tài)的常見方法

    查看MySQL是否處于運行狀態(tài)的常見方法

    在管理 MySQL 數(shù)據(jù)庫的過程中,了解并掌握如何查看 MySQL 的運行狀態(tài)至關(guān)重要,這不僅可以幫助我們及時發(fā)現(xiàn)潛在的問題,還能確保數(shù)據(jù)庫系統(tǒng)的穩(wěn)定性和性能,本文將詳細(xì)介紹通過不同的方法來查看 MySQL 是否處于運行狀態(tài)的常見方法
    2025-02-02
  • 簡單聊一聊SQL中的union和union?all

    簡單聊一聊SQL中的union和union?all

    在寫SQL的時候,偶爾會用到兩個表的數(shù)據(jù)結(jié)合在一起返回的,就需要用到UNION 和 UNION ALL,這篇文章主要給大家介紹了關(guān)于SQL中union和union?all的相關(guān)資料,需要的朋友可以參考下
    2023-02-02
  • MySQL連表查詢分組去重的實現(xiàn)示例

    MySQL連表查詢分組去重的實現(xiàn)示例

    本文將結(jié)合實例代碼,介紹MySQL連表查詢分組去重,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-07-07
  • MySQL查詢條件中in會用到索引嗎

    MySQL查詢條件中in會用到索引嗎

    這篇文章主要給大家介紹了MySQL查詢條件中in會不會用到索引的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • mysql Key_buffer_size參數(shù)的優(yōu)化設(shè)置

    mysql Key_buffer_size參數(shù)的優(yōu)化設(shè)置

    mysql數(shù)據(jù)庫中有許多重要的參數(shù),其中mysql key_buffer_size是對MyISAM表性能影響最大的一個參數(shù),下面就讓我們一起來了解一下
    2014-12-12

最新評論