国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

優(yōu)化MySQL數(shù)據(jù)庫性能的8方案

數(shù)據(jù)庫 MySQL
以下的文章主要介紹的是優(yōu)化MySQL數(shù)據(jù)庫性能的八條好用方案,以下就是具體方案的描述,希望在你今后的學(xué)習(xí)中會有所幫助。

此文主要討論的是如何正確提高MySQL 數(shù)據(jù)庫性能的方案,我們主要是從8個方面來給出其具體的解決方案。以下就是對正確提高M(jìn)ySQL 數(shù)據(jù)庫性能的方案的詳細(xì)內(nèi)容介紹,望大家借鑒。

 

1、選取最適用的字段屬性

MySQL可以很好的支持大數(shù)據(jù)量的存取,但是一般說來,MySQL數(shù)據(jù)庫中的表越小,在它上面執(zhí)行的查詢也就會越快。因此,在創(chuàng)建表的時候,為了獲得更 好的性能,我們可以將表中字段的寬度設(shè)得盡可能小。例如,在定義郵政編碼這個字段時,如果將其設(shè)置為CHAR(255),顯然給數(shù)據(jù)庫增加了不必要的空 間,甚至使用VARCHAR這種類型也是多余的,因?yàn)镃HAR(6)就可以很好的完成任務(wù)了。同樣的,如果可以的話,我們應(yīng)該使用MEDIUMINT而不 是BIGIN來定義整型字段。

另外一個提高效率的方法是在可能的情況下,應(yīng)該盡量把字段設(shè)置為NOT NULL,這樣在將來執(zhí)行查詢的時候,數(shù)據(jù)庫不用去比較NULL值。

對于某些文本字段,例如“省份”或者“性別”,我們可以將它們定義為ENUM類型。因?yàn)樵贛ySQL中,ENUM類型被當(dāng)作數(shù)值型數(shù)據(jù)來處理,而數(shù)值型數(shù)據(jù)被處理起來的速度要比文本類型快得多。這樣,我們又可以提高M(jìn)ySQL數(shù)據(jù)庫的性能。

2、使用連接(JOIN)來代替子查詢(Sub-Queries)

MySQL從4.1開始支持SQL的子查詢。這個技術(shù)可以使用SELECT語句來創(chuàng)建一個單列的查詢結(jié)果,然后把這個結(jié)果作為過濾條件用在另一 個查詢中。例如,我們要將客戶基本信息表中沒有任何訂單的客戶刪除掉,就可以利用子查詢先從銷售信息表中將所有發(fā)出訂單的客戶ID取出來,然后將結(jié)果傳遞 給主查詢,如下所示:

  1. DELETE FROM customerinfo  
  2. WHERE CustomerID NOT in (SELECT CustomerID FROM salesinfo ) 

使用子查詢可以一次性的完成很多邏輯上需要多個步驟才能完成的SQL操作,同時也可以避免事務(wù)或者表鎖死,并且寫起來也很容易。但是,有些情況 下,子查詢可以被更有效率的連接(JOIN).. 替代。例如,假設(shè)我們要將所有沒有訂單記錄的用戶取出來,可以用下面這個查詢完成:

  1. SELECT * FROM customerinfo  
  2. WHERE CustomerID NOT in (SELECT CustomerID FROM salesinfo ) 

如果使用連接(JOIN).. 來完成這個查詢工作,速度將會快很多。尤其是當(dāng)salesinfo表中對CustomerID建有索引的話,性能將會更好,查詢?nèi)缦拢?/p>

  1. SELECT * FROM customerinfo  
  2. LEFT JOIN salesinfoON customerinfo.CustomerID=salesinfo.  
  3. CustomerID  
  4. WHERE salesinfo.CustomerID IS NULL 

連接(JOIN).. 之所以更有效率一些,是因?yàn)?MySQL不需要在內(nèi)存中創(chuàng)建臨時表來完成這個邏輯上的需要兩個步驟的查詢工作。

3、使用聯(lián)合(UNION)來代替手動創(chuàng)建的臨時表

MySQL 從 4.0 的版本開始支持 UNION 查詢,它可以把需要使用臨時表的兩條或更多的 SELECT 查詢合并的一個查詢中。在客戶端的查詢會話結(jié)束的時候,臨時表會被自動刪除,從而保證MySQL數(shù)據(jù)庫整齊、高效。使用 UNION 來創(chuàng)建查詢的時候,我們只需要用 UNION作為關(guān)鍵字把多個 SELECT 語句連接起來就可以了,要注意的是所有 SELECT 語句中的字段數(shù)目要想同。下面的例子就演示了一個使用 UNION的查詢。

  1. SELECT Name, Phone FROM client  
  2. UNION  
  3. SELECT Name, BirthDate FROM author  
  4. UNION  
  5. SELECT Name, Supplier FROM product 

4、事務(wù)

盡管我們可以使用子查詢(Sub-Queries)、連接(JOIN)和聯(lián)合(UNION)來創(chuàng)建各種各樣的查詢,但不是所有的數(shù)據(jù)庫操作都可 以只用一條或少數(shù)幾條SQL語句就可以完成的。更多的時候是需要用到一系列的語句來完成某種工作。但是在這種情況下,當(dāng)這個語句塊中的某一條語句運(yùn)行出錯 的時候,整個語句塊的操作就會變得不確定起來。

設(shè)想一下,要把某個數(shù)據(jù)同時插入兩個相關(guān)聯(lián)的表中,可能會出現(xiàn)這樣的情況:第一個表中成功更新后,數(shù)據(jù)庫突 然出現(xiàn)意外狀況,造成第二個表中的操作沒有完成,這樣,就會造成數(shù)據(jù)的不完整,甚至?xí)茐臄?shù)據(jù)庫中的數(shù)據(jù)。要避免這種情況,就應(yīng)該使用事務(wù),它的作用是: 要么語句塊中每條語句都操作成功,要么都失敗。

換句話說,就是可以保持?jǐn)?shù)據(jù)庫中數(shù)據(jù)的一致性和完整性。事物以BEGIN 關(guān)鍵字開始,COMMIT關(guān)鍵字結(jié)束。在這之間的一條SQL操作失敗,那么,ROLLBACK命令就可以把MySQL數(shù)據(jù)庫恢復(fù)到BEGIN開始之前的狀態(tài)。

  1. BEGIN;  
  2. INSERT INTO salesinfo SET CustomerID=14;  
  3. UPDATE inventory SET Quantity=11 
  4. WHERE item=’book’;  
  5. COMMIT; 

事務(wù)的另一個重要作用是當(dāng)多個用戶同時使用相同的數(shù)據(jù)源時,它可以利用鎖定數(shù)據(jù)庫的方法來為用戶提供一種安全的訪問方式,這樣可以保證用戶的操作不被其它的用戶所干擾。

5、鎖定表

盡管事務(wù)是維護(hù)數(shù)據(jù)庫完整性的一個非常好的方法,但卻因?yàn)樗莫?dú)占性,有時會影響數(shù)據(jù)庫的性能,尤其是在很大的應(yīng)用系統(tǒng)中。由于在事務(wù)執(zhí)行的過程中,數(shù)據(jù)庫將會被鎖定,因此其它的用戶請求只能暫時等待直到該事務(wù)結(jié)束。如果一個數(shù)據(jù)庫系統(tǒng)只有少數(shù)幾個用戶

來使用,事務(wù)造成的影響不會成為一個太大的問題;但假設(shè)有成千上萬的用戶同時訪問一個MySQL數(shù)據(jù)庫系統(tǒng),例如訪問一個電子商務(wù)網(wǎng)站,就會產(chǎn)生比較嚴(yán)重的響應(yīng)延遲。

 

其實(shí),有些情況下我們可以通過鎖定表的方法來獲得更好的性能。下面的例子就用鎖定表的方法來完成前面一個例子中事務(wù)的功能。

  1. LOCK TABLE inventory WRITE  
  2. SELECT Quantity FROM inventory  
  3. WHEREItem=’book’;  
  4. …  
  5. UPDATE inventory SET Quantity=11 
  6. WHEREItem=’book’;  
  7. UNLOCK TABLES 

這里,我們用一個 SELECT 語句取出初始數(shù)據(jù),通過一些計(jì)算,用 UPDATE 語句將新值更新到表中。包含有 WRITE 關(guān)鍵字的 LOCK TABLE 語句可以保證在 UNLOCK TABLES 命令被執(zhí)行之前,不會有其它的訪問來對 inventory 進(jìn)行插入、更新或者刪除的操作。

6、使用外鍵

鎖定表的方法可以維護(hù)數(shù)據(jù)的完整性,但是它卻不能保證數(shù)據(jù)的關(guān)聯(lián)性。這個時候我們就可以使用外鍵。例如,外鍵可以保證每一條銷售記錄都指向某一 個存在的客戶。在這里,外鍵可以把customerinfo 表中的CustomerID映射到salesinfo表中CustomerID,任何一條沒有合法CustomerID的記錄都不會被更新或插入到 salesinfo中。

  1. CREATE TABLE customerinfo  
  2. (  
  3. CustomerID INT NOT NULL ,  
  4. PRIMARY KEY ( CustomerID )  
  5. TYPE = INNODB;  
  6.  
  7. CREATE TABLE salesinfo  
  8. (  
  9. SalesID INT NOT NULL,  
  10. CustomerID INT NOT NULL,  
  11. PRIMARY KEY(CustomerID, SalesID),  
  12. FOREIGN KEY (CustomerID) REFERENCES customerinfo  
  13. (CustomerID) ON DELETECASCADE  
  14. TYPE = INNODB;  

注意例子中的參數(shù)“ON DELETE CASCADE”。該參數(shù)保證當(dāng) customerinfo 表中的一條客戶記錄被刪除的時候,salesinfo 表中所有與該客戶相關(guān)的記錄也會被自動刪除。如果要在 MySQL 中使用外鍵,一定要記住在創(chuàng)建表的時候?qū)⒈淼念愋投x為事務(wù)安全表 InnoDB類型。該類型不是 MySQL 表的默認(rèn)類型。定義的方法是在 CREATE TABLE 語句中加上 TYPE=INNODB。如例中所示。

7、使用索引

索引是提高數(shù)據(jù)庫性能的常用方法,它可以令MySQL數(shù)據(jù)庫服務(wù)器以比沒有索引快得多的速度檢索特定的行,尤其是在查詢語句當(dāng)中包含有MAX(), MIN()和ORDERBY這些命令的時候,性能提高更為明顯。那該對哪些字段建立索引呢?一般說來,索引應(yīng)建立在那些將用于JOIN, WHERE判斷和ORDER BY排序的字段上。

盡量不要對數(shù)據(jù)庫中某個含有大量重復(fù)的值的字段建立索引。對于一個ENUM類型的字段來說,出現(xiàn)大量重復(fù)值是很有可能的情況,例如 customerinfo中的“province”.. 字段,在這樣的字段上建立索引將不會有什么幫助;相反,還有可能降低數(shù)據(jù)庫的性能。我們在創(chuàng)建表的時候可以同時創(chuàng)建合適的索引,也可以使用ALTER TABLE或CREATE INDEX在以后創(chuàng)建索引。

此外,MySQL

從版本3.23.23開始支持全文索引和搜索。全文索引在MySQL 中是一個FULLTEXT類型索引,但僅能用于MyISAM 類型的表。對于一個大的MySQL數(shù)據(jù)庫,將數(shù)據(jù)裝載到一個沒有FULLTEXT索引的表中,然后再使用ALTER TABLE或CREATE INDEX創(chuàng)建索引,將是非常快的。但如果將數(shù)據(jù)裝載到一個已經(jīng)有FULLTEXT索引的表中,執(zhí)行過程將會非常慢。

8、優(yōu)化的查詢語句

絕大多數(shù)情況下,使用索引可以提高查詢的速度,但如果SQL語句使用不恰當(dāng)?shù)脑挘饕龑o法發(fā)揮它應(yīng)有的作用。下面是應(yīng)該注意的幾個方面。首 先,最好是在相同類型的字段間進(jìn)行比較的操作。在MySQL 3.23版之前,這甚至是一個必須的條件。

例如不能將一個建有索引的INT字段和BIGINT字段進(jìn)行比較;但是作為特殊的情況,在CHAR類型的字段和 VARCHAR類型字段的字段大小相同的時候,可以將它們進(jìn)行比較。其次,在建有索引的字段上盡量不要使用函數(shù)進(jìn)行操作。

例如,在一個DATE類型的字段上使用YEAE()函數(shù)時,將會使索引不能發(fā)揮應(yīng)有的作用。所以,下面的兩個查詢雖然返回的結(jié)果一樣,但后者要比前者快得多。

  1. SELECT * FROM order WHERE YEAR(OrderDate)<2001;  
  2. SELECT * FROM order WHERE OrderDate<”2001-01-01″;  

同樣的情形也會發(fā)生在對數(shù)值型字段進(jìn)行計(jì)算的時候:

  1. SELECT * FROM inventory WHERE Amount/7<24;  
  2. SELECT * FROM inventory WHERE Amount<24*7  

上面的兩個查詢也是返回相同的結(jié)果,但后面的查詢將比前面的一個快很多。第三,在搜索字符型字段時,我們有時會使用 LIKE 關(guān)鍵字和通配符,這種做法雖然簡單,但卻也是以犧牲系統(tǒng)性能為代價的。例如下面的查詢將會比較表中的每一條記錄。

  1. SELECT * FROM books  
  2. WHERE name like “MySQL%” 

但是如果換用下面的查詢,返回的結(jié)果一樣,但速度就要快上很多:

  1. SELECT * FROM books  
  2. WHERE name>=”MySQL”and name<”MySQM” 

最后,應(yīng)該注意避免在查詢中讓MySQL進(jìn)行自動類型轉(zhuǎn)換,因?yàn)檗D(zhuǎn)換過程也會使索引變得不起作用。以上的相關(guān)內(nèi)容就是對MySQL數(shù)據(jù)庫性能優(yōu)化八條規(guī)則的介紹,望你能有所收獲。

 【編輯推薦】

  1. MySQL 4.1 數(shù)據(jù)轉(zhuǎn)換的指導(dǎo)
  2. 配置MySQL與卸載MySQL實(shí)操
  3. MySQL 修改密碼的6個好用方案
  4. MySQL數(shù)據(jù)庫訪問妙招在Linux之下
  5. 從MySQL數(shù)據(jù)庫表中來檢索數(shù)據(jù)并不難
責(zé)任編輯:佚名 來源: 博客園
相關(guān)推薦

2010-05-13 10:47:44

MySQL數(shù)據(jù)庫查詢

2010-06-17 09:15:02

MySQL數(shù)據(jù)庫查詢

2010-06-11 12:32:57

MySQL數(shù)據(jù)庫查詢

2010-05-18 16:58:31

MySQL數(shù)據(jù)庫

2010-05-27 18:36:13

配置MySQL

2010-06-01 17:14:28

2010-07-05 09:14:37

SQL Server數(shù)

2010-05-31 16:17:56

MySQL數(shù)據(jù)庫性能

2010-06-02 13:58:30

MySQL數(shù)據(jù)庫性能

2010-04-22 16:00:45

Oracle數(shù)據(jù)庫

2010-07-01 12:44:52

SQL Server數(shù)

2009-06-30 22:31:23

關(guān)鍵參數(shù)MySQL性能優(yōu)化

2011-07-06 10:49:50

MySQL優(yōu)化

2011-07-06 14:12:20

MySQLPercona

2011-03-09 08:53:02

MySQL優(yōu)化集群

2011-03-08 08:49:55

MySQL優(yōu)化單機(jī)

2010-06-01 16:26:43

MySQL無法遠(yuǎn)程

2013-09-17 10:32:08

Android性能優(yōu)化數(shù)據(jù)庫

2024-03-14 10:10:03

MySQL優(yōu)化事務(wù)

2024-01-18 09:43:11

MySQL數(shù)據(jù)庫
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

91久久精品网| 国产精品福利视频| 中文字幕在线观看日本| 久久精品一区二区三区不卡 | 国产精品一区二区三区精品| 调教视频免费在线观看| 亚洲综合精品自拍| 国产专区一区二区三区| 国产成人精品一区二区三区视频| 欧美精品尤物在线观看| 欧美大尺度在线观看| 成人日韩在线观看| 亚洲色在线视频| 欧美xo影院| 在线免费观看羞羞视频一区二区| 国内精品视频久久| 欧美天堂一区| 日韩视频免费观看| 欧美成人福利| 中文字幕国产亚洲| 成人国产在线| 中文字幕日韩有码| 日韩经典一区| 久久亚洲国产精品| 久久伊人久久| 午夜欧美大片免费观看| 豆花视频一区二区| 26uuu日韩精品一区二区| 国产精品视屏| 国产日韩中文字幕在线| 国产主播精品| 日韩中文一区| 成人中文字幕在线| 欧美日韩大尺度| 亚洲欧美欧美一区二区三区| 最近中文字幕在线| 日韩一区二区在线观看视频| 爱情电影社保片一区| 欧美成人精品h版在线观看| 免费成人高清在线视频theav| 成人网中文字幕| 天堂va蜜桃一区二区三区| 草草草视频在线观看| 国产嫩草影院久久久久| 免费激情网址| 欧美日韩精品欧美日韩精品| 乱馆动漫1~6集在线观看| 久久五月天色综合| 日韩欧美一区免费| 日韩av电影免费播放| 26uuu亚洲| 中文字幕在线视频观看| 欧美不卡一区二区三区四区| 亚洲精品毛片| 亚洲qvod图片区电影| 日本一区中文字幕| 国产精品无码av无码| 欧美午夜影院在线视频| 亚洲精品天堂| 久久久久久久久国产| 欧美性久久久| 毛片在线播放视频| 岛国av一区二区三区| 校园春色亚洲色图| 国产精品久久久久久久久久尿 | 亚洲大胆视频| 高清无码一区二区在线观看吞精| 亚洲视频在线一区观看| 毛片免费不卡| 欧美高清第一页| 尹人成人综合网| 日韩欧美国产精品一区| 亚洲十八**毛片| 欧美一级大片在线观看| 99精品视频免费| 天天影视综合色| 日韩午夜激情av| 蜜桃a∨噜噜一区二区三区| 日韩三级电影免费观看| 国产精品亲子乱子伦xxxx裸| gogo在线高清视频| 97视频在线观看免费| 美女精品在线观看| 欧美狂欢多p性派对| 亚洲精品国偷自产在线99热| 日韩精品二区| 日韩欧美精品在线观看视频| 91精品国产色综合久久ai换脸| 97一区二区国产好的精华液| 香蕉久久夜色| 亚洲超碰97人人做人人爱| 国产精品99久久久久久董美香| 99精品国产一区二区| 91视频精品在这里| 在线免费观看的av| 国产精品久久一区| 成人午夜在线视频| caopeng在线| 国产一区二区色| 欧美激情中文不卡| 毛片电影在线| 精品国产免费一区二区三区| 亚洲乱码日产精品bd| 成人a在线观看高清电影| 久久久久久久久一区二区| 天天综合色天天综合色h| 88久久精品| 亚洲精品少妇一区二区| 91精品国产全国免费观看| 欧美oldwomenvideos| 97在线免费| 日韩专区中文字幕| 日本va欧美va欧美va精品| 欧美成人免费| 国产欧美精品一区二区三区-老狼 国产欧美精品一区二区三区介绍 国产欧美精品一区二区 | 激情成人综合| 九色丨porny丨自拍入口| 日韩中文字幕网| 国产综合色产在线精品| av在线免费观看网址| 成人区精品一区二区| 亚洲国产乱码最新视频| 西野翔中文久久精品字幕| 50路60路老熟妇啪啪| 中文字幕久热精品视频在线| 国产精品小仙女| 久草在线资源福利站| 在线观看日韩羞羞视频| 欧美第一区第二区| 亚洲人www| 午夜伦理在线| 日本不卡二区高清三区| 91精品久久久久久久91蜜桃| 狠久久av成人天堂| 成人高清在线| 久久综合给合久久狠狠色| 欧美精品欧美精品系列| 99精品视频网| 午夜精品一区| 亚洲a∨一区二区三区| 精品国产百合女同互慰| 激情欧美日韩一区二区| 国产香蕉久久| 国产裸体舞一区二区三区| 久久久久久久久久久免费精品| 国产精品久久久久久久久免费丝袜 | 97视频精彩视频在线观看| 国产99午夜精品一区二区三区| 欧美视频免费在线| 中文精品久久| 一级日本在线| 亚洲精品一区二区三| 伊人一区二区三区久久精品 | 欧美视频国产精品| 国产精品豆花视频| 深夜国产在线播放| 无码毛片aaa在线| 久久亚洲精品网站| 亚洲特级片在线| 天天射—综合中文网| 麻豆视频网站在线观看| 一区二区精品视频| 最新国产精品亚洲| 国产精品视频观看| 四虎国产精品免费观看| 精品视频在线一区二区| 亚洲开发第一视频在线播放| 欧美成人激情视频| 欧美日韩另类字幕中文| 美国三级日本三级久久99| 日本免费一区二区三区视频| 在线观看av网站永久| 亚洲一卡二卡三卡四卡无卡网站在线看 | 久久久精品麻豆| 亚洲a级在线观看| 欧美精品一区二区三| 久久免费偷拍视频| 亚洲精品午夜av福利久久蜜桃| 变态调教一区二区三区| 无码无遮挡又大又爽又黄的视频| 91久久精品国产| 亚洲国内精品在线| 国产精品福利一区二区| 日韩视频不卡| 免费欧美网站| 一级毛片视频在线观看| 成人亚洲视频在线观看| 国产精品theporn88| 色777狠狠综合秋免鲁丝| 欧美性色19p| 国产**成人网毛片九色 | 国产精品一区二区免费不卡| 亚洲人成网www| 僵尸再翻生在线观看| 成年免费网站| 黄色一级视频播放| 91九色国产视频| 久久99精品国产99久久6尤物| 51精品久久久久久久蜜臀| 国产精品久久久久久久久免费相片|