亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

MySQL優化全攻略-相關數據庫命令

2020-01-19 00:27:12
字體:
來源:轉載
供稿:網友
接下來我們要討論的是數據庫性能優化的另一方面,即運用數據庫服務器內建的工具輔助性能分析和優化。  
   ▲ SHOW  
   執行下面這個命令可以了解服務器的運行狀態:  
mysql >show status; 
   該命令將顯示出一長列狀態變量及其對應的值,其中包括:被中止訪問的用戶數量,被中止的連接數量,嘗試連接的次數,并發連接數量最大值,以及其他許多有用的信息。這些信息對于確定系統問題和效率低下的原因是十分有用的。  
   SHOW命令除了能夠顯示出MySQL服務器整體狀態信息之外,它還能夠顯示出有關日志文件、指定數據庫、表、索引、進程和許可權限表的寶貴信息。請訪問http://www.mysql.com/doc/S/H/SHOW.html了解更多信息。  
   ▲ EXPLAIN  
   EXPLAIN能夠分析SELECT命令的處理過程。這不僅對于決定是否要為表加上索引很有用,而且對于了解MySQL處理復雜連接的過程也很有用。  
   下面這個例子顯示了如何用EXPLAIN提供的信息逐步地優化連接查詢。(本例來自MySQL文檔,見http://www.mysql.com/doc/E/X/EXPLAIN.html。原文寫到這里似乎有點潦草了事,特加上此例。)  
   假定用EXPLAIN分析的SELECT命令如下所示:  
EXPLAIN SELECT tt.TicketNumber, tt.TimeIn, 
      tt.ProjectReference, tt.EstimatedShipDate, 
      tt.ActualShipDate, tt.ClientID, 
      tt.ServiceCodes, tt.RepetitiveID, 
      tt.CurrentProcess, tt.CurrentDPPerson, 
      tt.RecordVolume, tt.DPPrinted, et.COUNTRY, 
      et_1.COUNTRY, do.CUSTNAME 
    FROM tt, et, et AS et_1, do 
    WHERE tt.SubmitTime IS NULL 
      AND tt.ActualPC = et.EMPLOYID 
      AND tt.AssignedPC = et_1.EMPLOYID 
      AND tt.ClientID = do.CUSTNMBR; 

   SELECT命令中出現的表定義如下:  
   ※表定義  
表 列 列類型  
tt ActualPC CHAR(10)  
tt AssignedPC CHAR(10)  
tt ClientID CHAR(10)  
et EMPLOYID CHAR(15)  
do CUSTNMBR CHAR(15)  

  ※索引  
表 索引  
tt ActualPC  
tt AssignedPC  
tt ClientID  
et EMPLOYID (主鍵)  
do CUSTNMBR (主鍵)  
   ※tt.ActualPC值分布不均勻  
   在進行任何優化之前,EXPLAIN對SELECT執行分析的結果如下:  
table type possible_keys        key key_len ref rows Extra 
et  ALL PRIMARY           NULL NULL  NULL 74 
do  ALL PRIMARY           NULL NULL  NULL 2135 
et_1 ALL PRIMARY           NULL NULL  NULL 74 
tt  ALL AssignedPC,ClientID,ActualPC NULL NULL  NULL 3872 
   range checked for each record (key map: 35) 

   每一個表的type都是ALL,它表明MySQL為每一個表進行了完全連接!這個操作是相當耗時的,因為待處理行的數量達到每一個表行數的乘積!即,這里的總處理行數為74 * 2135 * 74 * 3872 = 45,268,558,720。  
   這里的問題之一在于,如果數據庫列的聲明不同,MySQL(還)不能有效地運用列的索引。在這個問題上,VARCHAR和CHAR是一樣的,除非它們聲明的長度不同。由于tt.ActualPC聲明為CHAR(10),而et.EMPLOYID聲明為CHAR(15),因此這里存在列長度不匹配問題。  
   為了解決這兩個列的長度不匹配問題,用ALTER TABLE命令把ActualPC列從10個字符擴展到15字符,如下所示:  
mysql > ALTER TABLE tt MODIFY ActualPC VARCHAR(15); 

   現在tt.ActualPC和et.EMPLOYID都是VARCHAR(15)了,執行EXPLAIN進行分析得到的結果如下所示:  
table type  possible_keys  key   key_len ref     rows  Extra 
tt  ALL  AssignedPC,ClientID,ActualPC NULL NULL NULL 3872  where used 
do  ALL  PRIMARY     NULL  NULL  NULL    2135 
   range checked for each record (key map: 1) 
et_1 ALL  PRIMARY     NULL  NULL  NULL    74 
   range checked for each record (key map: 1) 
et  eq_ref PRIMARY     PRIMARY 15   tt.ActualPC 1 

   這還算不上完美,但已經好多了(行數的乘積現在少了一個系數74)?,F在這個SQL命令執行大概需要數秒鐘時間。  
   為了避免tt.AssignedPC = et_1.EMPLOYID以及tt.ClientID = do.CUSTNMBR比較中的列長度不匹配,我們可以進行如下改動:  
mysql > ALTER TABLE tt MODIFY AssignedPC VARCHAR(15), 
           MODIFY ClientID  VARCHAR(15); 

   現在EXPLAIN顯示的結果如下:  
table type  possible_keys  key   key_len ref      rows   Extra 
et  ALL  PRIMARY     NULL  NULL  NULL      74 
tt  ref  AssignedPC,ClientID,ActualPC ActualPC 15 et.EMPLOYID 52 where used 
et_1 eq_ref PRIMARY     PRIMARY 15   tt.AssignedPC 1 
do  eq_ref PRIMARY     PRIMARY 15   tt.ClientID  1 

   這個結果已經比較令人滿意了。 
   余下的問題在于,默認情況下,MySQL假定tt.ActualPC列的值均勻分布,而事實上tt表的情況并非如此。幸而,我們可以很容易地讓MySQL知道這一點:  
shell > myisamchk --analyze PATH_TO_MYSQL_DATABASE/tt 
shell > mysqladmin refresh 

   現在這個連接操作已經非常理想,EXPLAIN分析的結果如下:  
table type  possible_keys  key   key_len ref      rows  Extra 
tt  ALL  AssignedPC,ClientID,ActualPC NULL NULL NULL  3872  where used 
et  eq_ref PRIMARY     PRIMARY 15   tt.ActualPC  1 
et_1 eq_ref PRIMARY     PRIMARY 15   tt.AssignedPC 1 
do  eq_ref PRIMARY     PRIMARY 15   tt.ClientID  1 

   ▲ OPTIMIZE  
   OPTIMIZE能夠恢復和整理磁盤空間以及數據碎片,一旦對包含變長行的表進行了大量的更新或者刪除,進行這個操作就非常有必要了。OPTIMIZE當前只能用于MyISAM和BDB表。  
   結束語:從編譯數據庫服務器開始、貫穿整個管理過程,能夠改善MySQL性能的因素實在非常多,本文只涉及了其中很小的一部分。盡管如此,我們希望本文討論的內容能夠對你有所幫助。  
//copy者注: 
  時間不夠,所以格式上有點問題~~,請大家看詳細的英文原文:http://www.devshed.com/Server_Side/MySQL/Optimize/ 
或者看看chinabyte的文章好了: 
http://www.chinabyte.com/builder/detail.shtm?buiid=1012&parid=1 
哈哈~從這點能不能看出來我是全心全意為大家服務的
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美性极品xxxx娇小| 欧美日韩国产麻豆| 国产精品日韩在线播放| 国产成人小视频在线观看| 亚洲免费人成在线视频观看| 日韩中文字幕在线观看| 成人性生交大片免费观看嘿嘿视频| 性色av一区二区三区| 日本精品视频在线播放| 欧美精品videosex牲欧美| 欧美最近摘花xxxx摘花| 久久香蕉国产线看观看av| 亚洲国产高潮在线观看| 国产精品一区=区| 国产91在线高潮白浆在线观看| 中国日韩欧美久久久久久久久| 欧美日韩国产在线| 精品视频一区在线视频| 美日韩精品免费观看视频| 最近的2019中文字幕免费一页| 中文字幕在线看视频国产欧美在线看完整| 中文字幕免费精品一区高清| 亚洲一区中文字幕在线观看| 日韩精品丝袜在线| 日韩欧美在线视频日韩欧美在线视频| 欧美在线www| 91网站在线免费观看| 欧美猛少妇色xxxxx| 亚洲高清免费观看高清完整版| 亚洲jizzjizz日本少妇| 色伦专区97中文字幕| 久久久久久国产| 国产精品美女久久久久久免费| 伊人伊成久久人综合网小说| 欧美日韩另类字幕中文| 亚洲成人亚洲激情| 91高潮精品免费porn| 日韩在线观看视频免费| 日韩在线视频免费观看| 高清一区二区三区四区五区| 国产91色在线|| 国产欧美一区二区三区久久| 色综合男人天堂| 欧美在线观看视频| 国产盗摄xxxx视频xxx69| 亚洲人成网站777色婷婷| 亚洲第一免费播放区| 国产精品亚洲视频在线观看| 欧美日韩性视频在线| 亚洲欧美日韩中文视频| 欧美在线免费视频| 久久精品国产综合| 国产欧美在线视频| 一本大道久久加勒比香蕉| 欧美大成色www永久网站婷| 国产深夜精品福利| 亚洲一区二区福利| 国产精品久久久久久亚洲调教| 日韩福利伦理影院免费| 国产精品午夜一区二区欲梦| 91社区国产高清| 国产在线观看一区二区三区| 中文字幕精品在线| 国产精品一区专区欧美日韩| 亚洲精品www久久久| 国产精品日韩一区| 国产精品黄色影片导航在线观看| 日韩女优在线播放| 一区二区日韩精品| 成人久久久久爱| 色老头一区二区三区在线观看| 成人在线免费观看视视频| 亚洲第五色综合网| 国产成人啪精品视频免费网| 成人综合网网址| 精品视频久久久久久久| 国产精品91在线观看| 国产精品91久久| 国产精品久久色| 欧美大全免费观看电视剧大泉洋| 国内精品久久久久影院 日本资源| 91理论片午午论夜理片久久| 亚洲一区国产精品| 成人国产精品久久久久久亚洲| 全亚洲最色的网站在线观看| 日韩精品www| 91欧美精品午夜性色福利在线| 国产偷亚洲偷欧美偷精品| 欧美亚洲一级片| 免费不卡在线观看av| 国产精品盗摄久久久| 欧美午夜精品久久久久久人妖| 色yeye香蕉凹凸一区二区av| 欧美大片免费观看在线观看网站推荐| 中文字幕欧美视频在线| 欧美理论电影在线播放| 亚洲人成电影网站色…| 91在线网站视频| 77777少妇光屁股久久一区| 日本亚洲欧美成人| 亚洲成人三级在线| 奇米一区二区三区四区久久| 久久精品最新地址| 国产精品美女久久久久av超清| 成人女保姆的销魂服务| 久久久999精品免费| 欧美成人午夜激情在线| 九九久久久久99精品| 亚洲激情中文字幕| 亚洲乱码国产乱码精品精天堂| 精品香蕉在线观看视频一| 国产精品久久久久久久9999| 国产色婷婷国产综合在线理论片a| 精品久久久国产精品999| 亚洲xxxx妇黄裸体| 国产精品美女久久久久久免费| 亚洲国产精品高清久久久| 国产精品久久久久7777婷婷| 精品国产区一区二区三区在线观看| 欧美精品精品精品精品免费| 久久久天堂国产精品女人| 日韩毛片在线看| 曰本色欧美视频在线| 日本乱人伦a精品| 亚洲一区二区三区在线视频| 成人性生交大片免费看小说| 亚洲第一级黄色片| 亚洲乱码国产乱码精品精| 欧美成人免费视频| 在线观看中文字幕亚洲| 另类少妇人与禽zozz0性伦| 人九九综合九九宗合| 亚洲成人免费在线视频| 亚洲午夜色婷婷在线| 欧美日韩在线另类| 亚洲性无码av在线| 精品国模在线视频| 激情亚洲一区二区三区四区| 亚洲xxx视频| 久久综合伊人77777蜜臀| 欧美激情视频播放| 欧美最猛性xxxxx亚洲精品| 欧美二区在线播放| 久久男人av资源网站| xxxx性欧美| 久久久久久国产三级电影| 亚洲欧美综合精品久久成人| 一本色道久久88亚洲综合88| 欧美成人自拍视频| 欧美多人乱p欧美4p久久| 欧美极品少妇xxxxⅹ喷水| 国产免费一区二区三区香蕉精| 日韩网站在线观看| 91网站免费看| 欧美色播在线播放| 国产性猛交xxxx免费看久久| 久久精品国产亚洲| 欧美国产一区二区三区| 欧美激情一级二级| 91精品免费久久久久久久久| 亚洲国产日韩欧美在线动漫| 亚洲新声在线观看| 欧美视频在线免费看| 国产v综合ⅴ日韩v欧美大片|