這篇文章將為大家詳細(xì)講解有關(guān)人工智能自動sql優(yōu)化工具SQLTuning for SQL Server怎么用,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),青山湖企業(yè)網(wǎng)站建設(shè),青山湖品牌網(wǎng)站建設(shè),網(wǎng)站定制,青山湖網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,青山湖網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
針對這種情況,人工智能自動SQL優(yōu)化工具應(yīng)運(yùn)而生?,F(xiàn)在我就向大家介紹這樣一款工具:SQLTuning for SQL Server。
1. SQL Tuning 簡介
SQL Turning是Quest公司出品的Quest Central軟件中的一個(gè)工具。
QuestCentral是一款集成化、圖形化、跨平臺的數(shù)據(jù)庫管理解決方案,可以同時(shí)管理Oracle、DB2 和 SQL server 數(shù)據(jù)庫。它包含了如下的多個(gè)工具:
數(shù)據(jù)庫管理(DBA)數(shù)據(jù)庫監(jiān)控(Monitoring Pack)數(shù)據(jù)庫診斷 (Spotlight Diagnostics)數(shù)據(jù)庫分析 (Database Analysis)SQL優(yōu)化 (SQL Tuning)空間管理 (Space Management)壓力測試 (Load Generator)數(shù)據(jù)生成 (Data Generator)PL/SQL 開發(fā) (TOAD)專家建議 (Knowledge Expert)
今天,我們只介紹其中的SQL優(yōu)化(SQL Tuning for SQL Server) 的使用方法。
2. 使用SQL Tuning 優(yōu)化SQL
下面我們用SQLServer自帶的Northwind數(shù)據(jù)庫為例,幫助大家了解如何使用SQLTuning優(yōu)化SQL。
(1)建立連接。在QuestCentral主界面上的“Database”樹上選擇“SQLServer”,然后在下方出現(xiàn)的“Tools”框中選擇“SQLTuning”選項(xiàng),打開“Lanch SQL Tuning for SQL ServerConnections”對話框。我們在這里建立數(shù)據(jù)庫服務(wù)器的連接,以后的分析工作都會在它上面完成。
雙擊“NewConnection”圖標(biāo),在彈出窗口中輸入數(shù)據(jù)庫的信息,單擊“OK”,然后單擊“Connect”即可。
(2)分析原始SQL語句 。在打開窗口的“OriangalSQL”文本框內(nèi)輸入需要分析的原始SQL語句,代碼如下:
/*查詢賣出價(jià)個(gè)不同的同一貨物名稱*/select DISTINCT c.CompanyName,p.ProductNamefrom [Order Details] od1,[Order Details] od2 , Orders o1 , Orderso2,Customers c, Products pwhere od1.UnitPrice<>od2.UnitPrice andod1.ProductID=od2.ProductIDand od1.OrderID=o1.OrderIDand od2.OrderID=o2.OrderIDand o1.CustomerID=o2.CustomerIDand o1.CustomerID=C.CustomerID
首先在界面左上方選擇數(shù)據(jù)庫,然后點(diǎn)擊工具欄上的“Execute”按鈕,執(zhí)行原始的SQL語句,SQLTuning會自動分析SQL的執(zhí)行計(jì)劃,并把分析結(jié)果顯示到界面上。
(3)優(yōu)化SQL。
現(xiàn)在我們點(diǎn)擊工具欄上的“Optimize Statement”按鈕,讓SQLTuning開始優(yōu)化SQL,完成后,可以看到SQLTuning產(chǎn)生了34條與原始SQL等價(jià)的優(yōu)化方案。
(4)獲得最優(yōu)SQL。
接下來,我們來執(zhí)行上面產(chǎn)生的優(yōu)化方案,以選出性能最佳的等效SQL語句。在列表中選擇需要執(zhí)行的優(yōu)化方案(默認(rèn)已全部選中),然后點(diǎn)擊工具欄上的“Execute”按鈕旁邊的下拉菜單,選擇“ExecuteSelected”。等到所有SQL運(yùn)行完成后,點(diǎn)擊界面左方的“TuningResolution”按鈕,可以看到最優(yōu)的SQL已經(jīng)出來啦,運(yùn)行時(shí)間竟然可以提高52%
(5)學(xué)習(xí)書寫專家級的SQL語句。
通過上面的步驟,我們已經(jīng)可以實(shí)現(xiàn)自動優(yōu)化SQL語句,但更重要的是,我們還可以學(xué)習(xí)如何書寫這樣高性能的SQL語句。點(diǎn)擊界面左方的“CompareScenarios”按鈕,我們可以比較優(yōu)化方案和原始SQL中的任意2條SQL語句,SQLTuning會將它們之間的不同之處以不同顏色表示出來,還可以在下方的“執(zhí)行計(jì)劃”中,通過比較兩條SQL語句的執(zhí)行計(jì)劃的不同,來了解其中的差異。
關(guān)于人工智能自動sql優(yōu)化工具SQLTuning for SQL Server怎么用就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。