首頁 Java Java面試題 java面試——慢查詢

java面試——慢查詢

Nov 20, 2020 pm 03:24 PM
java 慢查詢 面試

java面試——慢查詢

我們先來看下面試題:

面試題:如何判斷SQL查詢運算不是慢sql、如何最佳化(阿里面試題)

#面試題:MySQL慢查詢開啟,語句分析(阿里面試題)

(學習影片分享:java教學影片

一、開啟mysql慢查詢

方式一:修改設定檔

在my.ini 增加幾行:

[mysqlld]
//定义查过多少秒的查询算是慢查询,我这里定义的是2秒
long_query_time=2

#5.0、5.1等版本配置如下选项
log-slow-queries="mysql_slow_query.log"
#5.5及以上版本配置如下选项
slow-query-log=On
slow_query_log_file="mysql_slow_query.log"

//记录下没有使用索引的query
log-query-not-using-indexes

(相關學習影片分享:java面試題目及答案

方式二:透過MySQL資料庫開啟慢查詢

mysql>set global slow_query_log=ON
mysql>set global long_query_time = 3600;
mysql>set global log_querise_not_using_indexes = ON;

二、執行一次慢查詢操作

其實想要執行一次有實際意義的慢查詢比較困難,因為在自己測試的時候,就算查詢有20萬個資料的海量表,也只需要0.幾秒。我們可以透過如下語句取代:

SELECT SLEEP(10);

三、查看慢查詢的數量
透過如下sql語句,來查看一共執行過幾次慢查詢:

show global status like '%slow%';

四、分析慢查詢日誌

方式一:透過工具分析

MySQL自帶了mysqldumpslow工具用來分析slow query日誌,除此之外,還有一些好用的開源工具。

這裡假設已儲存的日誌名稱為long.log

列出記錄次數最多的10個sql語句:

mysqldumpslow -s c -t 10 long.log

列出回傳記錄集最多的10個sql語句:

mysqldumpslow -s r -t 10 long.log

方式二:直接分析mysql慢查詢日誌

# Time: 121017 17:38:54 
# User@Host: root[root] @ localhost [127.0.0.1] 
# Query_time: 3.794217 Lock_time: 0.000000 Rows_sent: 1  Rows_examined: 4194304 
SET timestamp=1350466734; 
select * from wei where text='orange'; 
# Time: 121017 17:46:22 
# User@Host: root[root] @ localhost [127.0.0.1] 
# Query_time: 3.819219  Lock_time: 0.000000 Rows_sent: 0  Rows_examined: 4194304 
SET timestamp=1350467182; 
select * from wei where text='long';

相關推薦:java入門教學

以上是java面試——慢查詢的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

Rimworld Odyssey溫度指南和Gravtech
1 個月前 By Jack chen
Rimworld Odyssey如何釣魚
1 個月前 By Jack chen
我可以有兩個支付帳戶嗎?
1 個月前 By 下次还敢
初學者的Rimworld指南:奧德賽
1 個月前 By Jack chen
PHP變量範圍解釋了
3 週前 By 百草

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1603
29
PHP教程
1506
276
Edge PDF查看器不起作用 Edge PDF查看器不起作用 Aug 07, 2025 pm 04:36 PM

testthepdfinanotherapptoderineiftheissueiswiththefileoredge.2.enablethebuilt inpdfviewerbyTurningOff“ eflblyopenpenpenpenpenpdffilesexternally”和“ downloadpdffiles” inedgesettings.3.clearbrowsingdatainclorwearbrowsingdataincludingcookiesandcachedcachedfileresteroresoreloresorelorsolesoresolesoresolvereresoreorsolvereresoreolversorelesoresolvererverenn

優化複雜數據結構的嵌套foreach循環 優化複雜數據結構的嵌套foreach循環 Aug 06, 2025 pm 12:53 PM

要優化嵌套foreach循環,首先應避免冗餘迭代,可通過索引數據將時間複雜度從O(n×m)降至O(n m);其次,若結構非真正層級,應使用SelectMany等方法展平數據;第三,通過條件判斷提前跳出或跳過不必要的處理;第四,選擇合適的數據結構如字典或哈希集以提升查找效率;第五,在操作獨立且耗時的情況下可謹慎使用並行化;第六,將復雜邏輯提取為獨立方法或查詢以提升可讀性和可維護性。優化核心在於減少複雜度、合理組織數據,並始終評估嵌套的必要性,最終實現高效、清晰、可擴展的代碼。

用Docker將Java應用程序部署到Kubernetes 用Docker將Java應用程序部署到Kubernetes Aug 08, 2025 pm 02:45 PM

容器化Java應用:創建Dockerfile,使用基礎鏡像如eclipse-temurin:17-jre-alpine,複製JAR文件並定義啟動命令,通過dockerbuild構建鏡像並用dockerrun測試本地運行。 2.推送鏡像到容器註冊表:使用dockertag標記鏡像並推送到DockerHub等註冊表,需先登錄dockerlogin。 3.部署到Kubernetes:編寫deployment.yaml定義Deployment,設置副本數、容器鏡像和資源限制,編寫service.yaml創建

如何在Java中實現簡單的TCP客戶端? 如何在Java中實現簡單的TCP客戶端? Aug 08, 2025 pm 03:56 PM

Importjava.ioandjava.net.SocketforI/Oandsocketcommunication.2.CreateaSocketobjecttoconnecttotheserverusinghostnameandport.3.UsePrintWritertosenddataviaoutputstreamandBufferedReadertoreadserverresponsesfrominputstream.4.Usetry-with-resourcestoautomati

VS代碼快捷方式專注於Explorer面板 VS代碼快捷方式專注於Explorer面板 Aug 08, 2025 am 04:00 AM

VSCode中可通過快捷鍵快速切換面板與編輯區。要跳轉至左側資源管理器面板,使用Ctrl Shift E(Windows/Linux)或Cmd Shift E(Mac);返回編輯區可用Ctrl `或Esc或Ctrl 1~9。相比鼠標操作,鍵盤快捷鍵更高效且不打斷編碼節奏。其他技巧包括:Ctrl KCtrl E聚焦搜索框,F2重命名文件,Delete刪除文件,Enter打開文件,方向鍵展開/收起文件夾。

如何在Java執行準備好的聲明? 如何在Java執行準備好的聲明? Aug 06, 2025 pm 04:04 PM

加載JDBC驅動並建立數據庫連接;2.使用Connection.prepareStatement()創建含?佔位符的SQL語句;3.調用setString()、setInt()等方法從1開始設置參數值;4.根據SQL類型調用executeUpdate()、executeQuery()或execute()執行語句;5.使用try-with-resources自動關閉Connection、PreparedStatement和ResultSet資源,防止內存洩漏,確保安全高效地處理數據庫操作。

解決Java應用程序中的常見內存洩漏 解決Java應用程序中的常見內存洩漏 Aug 06, 2025 am 09:47 AM

staticfieldSholdingObjectReferencsCanpreventgarBageCollection; useWeakHashMaporCleanUpmechanisms.2.unclosedrosedressourceslikestreamsorconnectionscauseleaks; lovelySustry-with-with-resources.3.non-Staticinnernnerclennerclennerclassesretercrettercleterclasseclasseclesclesclescelectaticorstaticoravoiravoiravoiravoiravoiravoiravoiravoivoi

如何使用Mockito在Java中嘲笑? 如何使用Mockito在Java中嘲笑? Aug 07, 2025 am 06:32 AM

要有效使用Mockito進行Java單元測試,首先需添加Mockito依賴,Maven項目在pom.xml中加入mockito-core依賴,Gradle項目添加testImplementation'org.mockito:mockito-core:5.7.0';接著通過@Mock註解(配合@ExtendWith(MockitoExtension.class))或mock()方法創建模擬對象;然後使用when(...).thenReturn(...)等方式對模擬對象的方法行為進行存根,也可配置異

See all articles