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

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

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

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

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

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

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

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

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

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

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

  如果使用連接(JOIN).. 來完成這個查詢工作,速度將會快很多。尤其是當salesinfo表中對CustomerID建有索引的話,性能將會更好,查詢如下:

SELECT * FROM customerinfo
LEFT JOIN salesinfoON customerinfo.CustomerID=salesinfo.
CustomerID
WHERE salesinfo.CustomerID IS NULL

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

  3、使用聯合(UNION)來代替手動創建的臨時表

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

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

  4、事務

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

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


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

 5、鎖定表

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

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

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

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

  6、使用外鍵

  鎖定表的方法可以維護數據的完整性,但是它卻不能保證數據的關聯性。這個時候我們就可以使用外鍵。例如,外鍵可以保證每一條銷售記錄都指向某一個存在 的客戶。在這里,外鍵可以把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;

  注意例子中的參數“ON DELETE CASCADE”。該參數保證當 customerinfo 表中的一條客戶記錄被刪除的時候,salesinfo 表中所有與該客戶相關的記錄也會被自動刪除。如果要在 MySQL 中使用外鍵,一定要記住在創建表的時候將表的類型定義為事務安全表 InnoDB類型。該類型不是 MySQL 表的默認類型。定義的方法是在 CREATE TABLE 語句中加上 TYPE=INNODB。如例中所示。

  7、使用索引

  索引是提高數據庫性能的常用方法,它可以令數據庫服務器以比沒有索引快得多的速度檢索特定的行,尤其是在查詢語句當中包含有MAX(), MIN()和ORDERBY這些命令的時候,性能提高更為明顯。那該對哪些字段建立索引呢?一般說來,索引應建立在那些將用于JOIN, WHERE判斷和ORDER BY排序的字段上。盡量不要對數據庫中某個含有大量重復的值的字段建立索引。對于一個ENUM類型的字段來說,出現大量重復值是很有可能的情況,例如 customerinfo中的“province”.. 字段,在這樣的字段上建立索引將不會有什么幫助;相反,還有可能降低數據庫的性能。我們在創建表的時候可以同時創建合適的索引,也可以使用ALTER TABLE或CREATE INDEX在以后創建索引。此外,MySQL
從版本3.23.23開始支持全文索引和搜索。全文索引在MySQL 中是一個FULLTEXT類型索引,但僅能用于MyISAM 類型的表。對于一個大的數據庫,將數據裝載到一個沒有FULLTEXT索引的表中,然后再使用ALTER TABLE或CREATE INDEX創建索引,將是非常快的。但如果將數據裝載到一個已經有FULLTEXT索引的表中,執行過程將會非常慢。

  8、優化的查詢語句

  絕大多數情況下,使用索引可以提高查詢的速度,但如果SQL語句使用不恰當的話,索引將無法發揮它應有的作用。下面是應該注意的幾個方面。首先,最好 是在相同類型的字段間進行比較的操作。在MySQL 3.23版之前,這甚至是一個必須的條件。例如不能將一個建有索引的INT字段和BIGINT字段進行比較;但是作為特殊的情況,在CHAR類型的字段和 VARCHAR類型字段的字段大小相同的時候,可以將它們進行比較。其次,在建有索引的字段上盡量不要使用函數進行操作。

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

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

  同樣的情形也會發生在對數值型字段進行計算的時候:

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

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

SELECT * FROM books
WHERE name like "MySQL%"

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

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

  最后,應該注意避免在查詢中讓MySQL進行自動類型轉換,因為轉換過程也會使索引變得不起作用。
選自:
http://space.itpub.net/47598/viewspace-329728
posted on 2009-11-24 17:01 chatler 閱讀(298) 評論(0)  編輯 收藏 引用 所屬分類: Database
<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

常用鏈接

留言簿(10)

隨筆分類(307)

隨筆檔案(297)

algorithm

Books_Free_Online

C++

database

Linux

Linux shell

linux socket

misce

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

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>
            欧美成人精品| 一区二区三区鲁丝不卡| 欧美+日本+国产+在线a∨观看| 亚洲深夜福利网站| 一区二区日韩免费看| 亚洲视频在线视频| 久久久天天操| 亚洲人成欧美中文字幕| 亚洲国产综合91精品麻豆| 亚洲国产精品123| 亚洲精品欧美极品| 宅男精品视频| 亚洲欧美不卡| 久久久视频精品| 欧美成人精品高清在线播放| 亚洲第一色中文字幕| 欧美韩国日本一区| 一本色道久久综合狠狠躁的推荐| 亚洲婷婷综合色高清在线| 欧美一区二区在线| 免费成人黄色| 国产精品美女999| 一区二区三区在线免费视频| 日韩视频中文字幕| 久久精品国产清高在天天线| 亚洲高清久久网| 午夜精品福利一区二区三区av | 国产精品无人区| 很黄很黄激情成人| 99热免费精品在线观看| 欧美伊人精品成人久久综合97 | 久久国产精品高清| 免费人成精品欧美精品| 亚洲精品视频一区| 久久国产精品久久国产精品| 欧美va天堂在线| 国产视频精品免费播放| 日韩一级免费| 久久欧美中文字幕| 一区二区三区.www| 欧美99久久| 国产午夜精品理论片a级大结局 | 新狼窝色av性久久久久久| 另类av导航| 亚洲综合视频一区| 欧美大片一区二区| 狠狠网亚洲精品| 午夜亚洲福利| 99精品欧美一区二区三区综合在线 | 老司机一区二区| 国产乱码精品一区二区三区五月婷| 亚洲丶国产丶欧美一区二区三区| 欧美在线一二三区| 亚洲视频在线播放| 欧美三级电影大全| 亚洲无限乱码一二三四麻| 亚洲丁香婷深爱综合| 蜜臀va亚洲va欧美va天堂| 亚洲一级黄色av| 欧美屁股在线| 亚洲精品网站在线播放gif| 狂野欧美激情性xxxx| 欧美一区二区黄| 国产精品国产三级国产专播精品人 | 久久精品在线| 国产美女扒开尿口久久久| 一区二区三区欧美成人| 亚洲国产天堂久久国产91| 久久久久久网| 极品少妇一区二区三区| 久久久久一区| 性欧美8khd高清极品| 国产精品久久久久91| 在线一区欧美| 999亚洲国产精| 欧美日韩亚洲高清| 亚洲午夜小视频| 日韩一级大片| 欧美日韩在线不卡一区| 在线亚洲一区二区| 在线视频精品| 国产精品一区二区久久精品| 校园春色国产精品| 欧美一区二区三区在线看 | 亚洲欧美国产毛片在线| 亚洲午夜高清视频| 国产三级欧美三级| 欧美成人性网| 欧美色偷偷大香| 香蕉成人伊视频在线观看| 久久精品国产亚洲一区二区| 在线观看成人av电影| 国产精品99久久久久久www| 亚洲美女精品久久| 国产精品永久在线| 免费观看亚洲视频大全| 欧美高清视频一二三区| 亚洲性视频h| 欧美在线free| 一区二区高清| 欧美一级网站| 亚洲人午夜精品| 亚洲一区3d动漫同人无遮挡| 国产午夜精品一区理论片飘花 | 一区二区三区高清在线| 亚洲免费伊人电影在线观看av| 国内精品免费在线观看| 久久精品亚洲国产奇米99| 久久蜜桃香蕉精品一区二区三区| 亚洲美女少妇无套啪啪呻吟| 亚洲综合精品四区| 亚洲美女电影在线| 久久se精品一区精品二区| aa日韩免费精品视频一| 欧美一区二区网站| 亚洲在线观看视频| 老色批av在线精品| 久久成人18免费观看| 欧美男人的天堂| 麻豆成人精品| 国产美女精品一区二区三区 | 亚洲精品乱码久久久久| 亚洲欧美在线播放| 亚洲人成小说网站色在线| 亚洲一区二区三区欧美 | 久久久噜噜噜久久狠狠50岁| 欧美人与禽性xxxxx杂性| 久久伊人亚洲| 国产精品日日摸夜夜添夜夜av| 亚洲国产91| 一区二区视频免费在线观看| 亚洲男人的天堂在线| 亚洲视频精品在线| 欧美成人国产一区二区| 欧美18av| 影音先锋亚洲精品| 久久精品毛片| 久久亚洲综合网| 国产亚洲第一区| 亚洲欧美一区二区三区在线| 午夜久久久久久| 国产精品乱码一区二三区小蝌蚪| 亚洲精品黄色| 久久婷婷国产综合精品青草| 欧美小视频在线| 亚洲欧洲在线看| 亚洲国产片色| 嫩草影视亚洲| 亚洲国产国产亚洲一二三| 亚洲国产精品视频一区| 久久全球大尺度高清视频| 久久综合五月天婷婷伊人| 国产主播在线一区| 久久久国产一区二区| 每日更新成人在线视频| 在线不卡中文字幕| 欧美成人黄色小视频| 亚洲精品免费一二三区| 亚洲一区二区不卡免费| 国产精品久久精品日日| 午夜精品久久久久影视| 久久天天躁狠狠躁夜夜爽蜜月| 黄色综合网站| 欧美国产日韩在线| 亚洲剧情一区二区| 欧美一区二区日韩一区二区| 黄色成人av网| 欧美精品一区二区三区久久久竹菊| 99在线|亚洲一区二区| 性18欧美另类| ●精品国产综合乱码久久久久| 一区二区三区 在线观看视频| 一区二区三区 在线观看视| 国产精品久久二区二区| 欧美在线一二三区| 亚洲国内欧美| 欧美一区二区黄色| 在线精品视频一区二区| 欧美精品91| 亚洲欧美日韩天堂| 欧美福利在线观看| 亚洲香蕉在线观看| 狠狠色狠狠色综合| 欧美三级视频在线播放| 久久精品理论片| 一区二区免费看| 免费黄网站欧美| 香蕉久久a毛片| 亚洲精品一区二区三区樱花| 国产精品日韩高清| 欧美精品一区二区视频| 亚洲深夜福利视频| 欧美护士18xxxxhd| 久久国内精品自在自线400部| 亚洲人成毛片在线播放女女| 国产综合一区二区| 国产精品青草久久久久福利99| 欧美成年人网| 久久精品国产精品| 亚洲欧美日韩视频二区|