青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 297,  comments - 15,  trackbacks - 0
本文探討了提高MySQL 數(shù)據(jù)庫性能的思路,并從8個方面給出了具體的解決方法。

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

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

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

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

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

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

DELETE FROM customerinfo
WHERE CustomerID NOT in (SELECT CustomerID FROM salesinfo )

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

SELECT * FROM customerinfo
WHERE CustomerID NOT in (SELECT CustomerID FROM salesinfo )

  如果使用連接(JOIN).. 來完成這個查詢工作,速度將會快很多。尤其是當(dāng)salesinfo表中對CustomerID建有索引的話,性能將會更好,查詢?nèi)缦拢?br style="LINE-HEIGHT: normal; WORD-BREAK: break-all">
SELECT * FROM customerinfo
LEFT JOIN salesinfoON customerinfo.CustomerID=salesinfo.
CustomerID
WHERE salesinfo.CustomerID IS NULL

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

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

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

SELECT Name, Phone FROM client
UNION
SELECT Name, BirthDate FROM author
UNION
SELECT Name, Supplier FROM product

  4、事務(wù)

  盡管我們可以使用子查詢(Sub-Queries)、連接(JOIN)和聯(lián)合(UNION)來創(chuàng)建各種各樣的查詢,但不是所有的數(shù)據(jù)庫操作都可以只用 一條或少數(shù)幾條SQL語句就可以完成的。更多的時候是需要用到一系列的語句來完成某種工作。但是在這種情況下,當(dāng)這個語句塊中的某一條語句運行出錯的時 候,整個語句塊的操作就會變得不確定起來。設(shè)想一下,要把某個數(shù)據(jù)同時插入兩個相關(guān)聯(lián)的表中,可能會出現(xiàn)這樣的情況:第一個表中成功更新后,數(shù)據(jù)庫突然出 現(xiàn)意外狀況,造成第二個表中的操作沒有完成,這樣,就會造成數(shù)據(jù)的不完整,甚至?xí)茐臄?shù)據(jù)庫中的數(shù)據(jù)。要避免這種情況,就應(yīng)該使用事務(wù),它的作用是:要么 語句塊中每條語句都操作成功,要么都失敗。換句話說,就是可以保持數(shù)據(jù)庫中數(shù)據(jù)的一致性和完整性。事物以BEGIN 關(guān)鍵字開始,COMMIT關(guān)鍵字結(jié)束。在這之間的一條SQL操作失敗,那么,ROLLBACK命令就可以把數(shù)據(jù)庫恢復(fù)到BEGIN開始之前的狀態(tài)。

BEGIN;
INSERT INTO salesinfo SET CustomerID=14;
UPDATE inventory SET Quantity=11
WHERE item='book';
COMMIT;


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

 5、鎖定表

  盡管事務(wù)是維護數(shù)據(jù)庫完整性的一個非常好的方法,但卻因為它的獨占性,有時會影響數(shù)據(jù)庫的性能,尤其是在很大的應(yīng)用系統(tǒng)中。由于在事務(wù)執(zhí)行的過程中,數(shù)據(jù)庫將會被鎖定,因此其它的用戶請求只能暫時等待直到該事務(wù)結(jié)束。如果一個數(shù)據(jù)庫系統(tǒng)只有少數(shù)幾個用戶
來使用,事務(wù)造成的影響不會成為一個太大的問題;但假設(shè)有成千上萬的用戶同時訪問一個數(shù)據(jù)庫系統(tǒng),例如訪問一個電子商務(wù)網(wǎng)站,就會產(chǎn)生比較嚴重的響應(yīng)延遲。

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

LOCK TABLE inventory WRITE
SELECT Quantity FROM inventory
WHEREItem='book';
...
UPDATE inventory SET Quantity=11
WHEREItem='book';
UNLOCK TABLES

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

  6、使用外鍵

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

CREATE TABLE customerinfo
(
CustomerID INT NOT NULL ,
PRIMARY KEY ( CustomerID )
) TYPE = INNODB;

CREATE TABLE salesinfo
(
SalesID INT NOT NULL,
CustomerID INT NOT NULL,
PRIMARY KEY(CustomerID, SalesID),
FOREIGN KEY (CustomerID) REFERENCES customerinfo
(CustomerID) ON DELETECASCADE
) TYPE = INNODB;

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

  7、使用索引

  索引是提高數(shù)據(jù)庫性能的常用方法,它可以令數(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 類型的表。對于一個大的數(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)該注意的幾個方面。首先,最好 是在相同類型的字段間進行比較的操作。在MySQL 3.23版之前,這甚至是一個必須的條件。例如不能將一個建有索引的INT字段和BIGINT字段進行比較;但是作為特殊的情況,在CHAR類型的字段和 VARCHAR類型字段的字段大小相同的時候,可以將它們進行比較。其次,在建有索引的字段上盡量不要使用函數(shù)進行操作。

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

SELECT * FROM order WHERE YEAR(OrderDate)<2001;
SELECT * FROM order WHERE OrderDate<"2001-01-01";

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

SELECT * FROM inventory WHERE Amount/7<24;
SELECT * FROM inventory WHERE Amount<24*7;

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

SELECT * FROM books
WHERE name like "MySQL%"

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

SELECT * FROM books
WHERE name>="MySQL"and name<"MySQM"

  最后,應(yīng)該注意避免在查詢中讓MySQL進行自動類型轉(zhuǎn)換,因為轉(zhuǎn)換過程也會使索引變得不起作用。
選自:
http://space.itpub.net/47598/viewspace-329728
posted on 2009-11-24 17:01 chatler 閱讀(300) 評論(0)  編輯 收藏 引用 所屬分類: Database
<2009年5月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

常用鏈接

留言簿(10)

隨筆分類(307)

隨筆檔案(297)

algorithm

Books_Free_Online

C++

database

Linux

Linux shell

linux socket

misce

  • cloudward
  • 感覺這個博客還是不錯,雖然做的東西和我不大相關(guān),覺得看看還是有好處的

network

OSS

  • Google Android
  • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
  • os161 file list

overall

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美福利一区二区| 久久爱另类一区二区小说| 欧美美女bbbb| 一区二区日韩伦理片| 亚洲欧美中文另类| 国产欧美日韩亚州综合| 欧美亚洲自偷自偷| 国产亚洲精品激情久久| 久久亚洲私人国产精品va| 欧美激情第三页| 中文精品视频| 国产日韩欧美日韩| 欧美gay视频| 久久久欧美精品| 亚洲日本成人女熟在线观看| 欧美日韩网站| 久久精品国产精品亚洲综合 | 午夜久久电影网| 美女日韩欧美| 亚洲一区二区在| 国内精品模特av私拍在线观看| 免费人成网站在线观看欧美高清 | 亚洲中字黄色| 欧美 日韩 国产 一区| 亚洲视频大全| 在线精品视频一区二区三四| 欧美色综合网| 老**午夜毛片一区二区三区| 亚洲视频在线播放| 欧美成人免费网站| 欧美一级电影久久| 亚洲九九精品| 伊人久久亚洲美女图片| 国产精品国产三级国产普通话99| 久久久久久久欧美精品| 亚洲午夜激情网站| 亚洲国产日韩在线| 久久精品国产v日韩v亚洲| 亚洲精品中文字幕有码专区| 国产一区二区三区直播精品电影| 欧美日韩999| 美女免费视频一区| 欧美影院在线| 久久本道综合色狠狠五月| 国产精品高清免费在线观看| 一本色道婷婷久久欧美| 欧美电影电视剧在线观看| 欧美一区二区三区四区视频 | 亚洲国产成人91精品| 欧美中文字幕在线视频| 亚洲无吗在线| 一本大道久久精品懂色aⅴ| 伊人成年综合电影网| 国产日韩欧美精品一区| 欧美午夜欧美| 欧美日韩在线综合| 欧美激情视频给我| 欧美va亚洲va国产综合| 久久一区激情| 久久蜜桃精品| 久久久久久久久伊人| 欧美伊久线香蕉线新在线| 亚洲欧美日韩精品一区二区| 亚洲一区尤物| 亚洲综合另类| 午夜一级久久| 香蕉视频成人在线观看| 午夜激情亚洲| 欧美一区二区女人| 性欧美激情精品| 欧美一级理论片| 欧美在线免费视屏| 欧美专区在线观看一区| 久久精品午夜| 猛干欧美女孩| 欧美激情在线免费观看| 欧美精品激情在线| 欧美日韩视频免费播放| 欧美视频在线播放| 国产精品日日做人人爱| 国产婷婷成人久久av免费高清| 国产深夜精品福利| 一区二区自拍| 日韩视频一区二区在线观看| 一本色道久久99精品综合 | 欧美激情视频在线播放| 亚洲电影av在线| 日韩视频在线一区| 亚洲视频www| 欧美在线播放一区二区| 久久久爽爽爽美女图片| 欧美岛国激情| 国产精品久久国产愉拍| 国产一区二区你懂的| 亚洲国产一区二区a毛片| 日韩视频免费| 欧美在线播放一区| 欧美va亚洲va国产综合| 亚洲精品黄色| 亚洲欧美在线磁力| 久久亚洲精品视频| 欧美日韩在线三级| 国产视频自拍一区| 亚洲伦理在线免费看| 亚洲欧美福利一区二区| 老司机一区二区三区| 亚洲三级影院| 欧美综合国产精品久久丁香| 欧美精品一级| 国产一区二区三区在线观看免费 | 欧美亚男人的天堂| 国产一区99| 一本色道久久综合亚洲精品小说 | 日韩午夜在线| 久久精品日产第一区二区三区| 欧美国产日本高清在线| 亚洲综合日韩| 欧美激情在线观看| 国内精品99| 亚洲女同精品视频| 亚洲福利国产| 欧美呦呦网站| 国产精品久久激情| 亚洲精品社区| 毛片一区二区| 亚洲欧美制服另类日韩| 欧美精品激情blacked18| 海角社区69精品视频| 亚洲淫片在线视频| 亚洲成色777777在线观看影院| 欧美一区午夜精品| 国产精品第三页| 99精品免费| 欧美激情偷拍| 久久在线免费观看| 国产亚洲午夜| 欧美一区二区三区在线播放| 亚洲精品之草原avav久久| 久久深夜福利免费观看| 国产亚洲欧洲997久久综合| 亚洲在线1234| 亚洲六月丁香色婷婷综合久久| 老司机精品视频一区二区三区| 国产一区成人| 欧美在线播放一区二区| 亚洲无限乱码一二三四麻| 欧美精品一区二区三区在线看午夜 | 亚洲精品123区| 久久偷窥视频| 一区在线观看| 久久久另类综合| 欧美亚洲视频在线观看| 国产啪精品视频| 欧美亚洲在线播放| 亚洲欧美一级二级三级| 国产精品自拍一区| 亚欧成人精品| 亚洲影院色无极综合| 国产精品一区2区| 午夜视频精品| 欧美一级淫片aaaaaaa视频| 国产婷婷精品| 久久深夜福利免费观看| 久久久91精品| 亚洲欧洲精品一区二区三区波多野1战4| 久热精品视频| 巨乳诱惑日韩免费av| 亚洲人成免费| 日韩视频在线观看国产| 国产精品久久久久7777婷婷| 性欧美videos另类喷潮| 午夜日韩在线观看| 激情五月综合色婷婷一区二区| 久久久久久久一区二区| 久久久久久久一区二区| 亚洲欧洲在线一区| 亚洲精品一区在线| 欧美体内谢she精2性欧美| 香蕉乱码成人久久天堂爱免费 | 午夜视频精品| 黄网站色欧美视频| 亚洲第一精品在线| 国产精品成人播放| 久久久999国产| 女人色偷偷aa久久天堂| 中文av一区二区| 欧美在线免费视频| 亚洲精品国精品久久99热| 一二三四社区欧美黄| 国产在线乱码一区二区三区| 欧美二区视频| 欧美午夜一区二区福利视频| 久久久久久久网| 欧美精品v国产精品v日韩精品 | 久久久久高清| 亚洲无线一线二线三线区别av| 亚洲欧美清纯在线制服| 永久免费精品影视网站| 亚洲老司机av| 黄色一区二区在线|