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

colorful

zc qq:1337220912

 

為數(shù)據(jù)庫建立索引

最普通的情況,是為出現(xiàn)在where子句的字段建一個索引。為方便講述,我們先建立一個如下的表。
CREATE TABLE mytable (
 id serial primary key,
 category_id int not null default 0,
 user_id int not null default 0,
 adddate int not null default 0
);
如果你在查詢時常用類似以下的語句:
 SELECT * FROM mytable WHERE category_id=1;
最直接的應(yīng)對之道,是為category_id建立一個簡單的索引:
 CREATE INDEX mytable_categoryid
 ON mytable (category_id);
OK.如果你有不止一個選擇條件呢?例如:
 SELECT * FROM mytable WHERE category_id=1 AND user_id=2;
你的第一反應(yīng)可能是,再給user_id建立一個索引。不好,這不是一個最佳的方法。你可以建立多重的索引。
CREATE INDEX mytable_categoryid_userid ON mytable (category_id,user_id);
注意到我在命名時的習(xí)慣了嗎?我使用"表名_字段1名_字段2名"的方式。你很快就會知道我為什么這樣做了。
現(xiàn)在你已經(jīng)為適當(dāng)?shù)淖侄谓⒘怂饕贿^,還是有點不放心吧,你可能會問,數(shù)據(jù)庫會真正用到這些索引嗎?測試一下就OK,對于大多數(shù)的數(shù)據(jù)庫來說,這是很容易的,只要使用EXPLAIN命令:
EXPLAIN
 SELECT * FROM mytable
WHERE category_id=1 AND user_id=2;
 This is what Postgres 7.1 returns (exactly as I expected)
 NOTICE: QUERY PLAN:
 Index Scan using mytable_categoryid_userid on
 mytable (cost=0.00..2.02 rows=1 width=16)
EXPLAIN
以上是postgres的數(shù)據(jù),可以看到該數(shù)據(jù)庫在查詢的時候使用了一個索引(一個好開始),而且它使用的是我創(chuàng)建的第二個索引。看到我上面命名的好處了吧,你馬上知道它使用適當(dāng)?shù)乃饕恕?/p>

接著,來個稍微復(fù)雜一點的,如果有個ORDER BY字句呢?不管你信不信,大多數(shù)的數(shù)據(jù)庫在使用order by的時候,都將會從索引中受益。
 SELECT * FROM mytable
WHERE category_id=1 AND user_id=2
 ORDER BY adddate DESC;

很簡單,就象為where字句中的字段建立一個索引一樣,也為ORDER BY的字句中的字段建立一個索引:
 CREATE INDEX mytable_categoryid_userid_adddate
 ON mytable (category_id,user_id,adddate);
 注意: "mytable_categoryid_userid_adddate" 將會被截短為
"mytable_categoryid_userid_addda"
 CREATE
 EXPLAIN SELECT * FROM mytable
WHERE category_id=1 AND user_id=2
 ORDER BY adddate DESC;
 NOTICE: QUERY PLAN:
 Sort (cost=2.03..2.03 rows=1 width=16)
-> Index Scan using mytable_categoryid_userid_addda
 on mytable (cost=0.00..2.02 rows=1 width=16)
 EXPLAIN
看看EXPLAIN的輸出,數(shù)據(jù)庫多做了一個我們沒有要求的排序,這下知道性能如何受損了吧,看來我們對于數(shù)據(jù)庫的自身運作是有點過于樂觀了,那么,給數(shù)據(jù)庫多一點提示吧。
為 了跳過排序這一步,我們并不需要其它另外的索引,只要將查詢語句稍微改一下。這里用的是postgres,我們將給該數(shù)據(jù)庫一個額外的提示--在 ORDER BY語句中,加入where語句中的字段。這只是一個技術(shù)上的處理,并不是必須的,因為實際上在另外兩個字段上,并不會有任何的排序操作,不過如果加 入,postgres將會知道哪些是它應(yīng)該做的。
 EXPLAIN SELECT * FROM mytable
WHERE category_id=1 AND user_id=2
 ORDER BY category_id DESC,user_id DESC,adddate DESC;
 NOTICE: QUERY PLAN:
 Index Scan Backward using
mytable_categoryid_userid_addda on mytable
 (cost=0.00..2.02 rows=1 width=16)
 EXPLAIN
現(xiàn)在使用我們料想的索引了,而且它還挺聰明,知道可以從索引后面開始讀,從而避免了任何的排序。
以 上說得細(xì)了一點,不過如果你的數(shù)據(jù)庫非常巨大,并且每日的頁面請求達(dá)上百萬算,我想你會獲益良多的。不過,如果你要做更為復(fù)雜的查詢呢,例如將多張表結(jié)合 起來查詢,特別是where限制字句中的字段是來自不止一個表格時,應(yīng)該怎樣處理呢?我通常都盡量避免這種做法,因為這樣數(shù)據(jù)庫要將各個表中的東西都結(jié)合 起來,然后再排除那些不合適的行,搞不好開銷會很大。
如果不能避免,你應(yīng)該查看每張要結(jié)合起來的表,并且使用以上的策略來建立索引,然后再用EXPLAIN命令驗證一下是否使用了你料想中的索引。如果是的話,就OK。不是的話,你可能要建立臨時的表來將他們結(jié)合在一起,并且使用適當(dāng)?shù)乃饕?
要注意的是,建立太多的索引將會影響更新和插入的速度,因為它需要同樣更新每個索引文件。對于一個經(jīng)常需要更新和插入的表格,就沒有必要為一個很少使用的where字句單獨建立索引了,對于比較小的表,排序的開銷不會很大,也沒有必要建立另外的索引。
以 上介紹的只是一些十分基本的東西,其實里面的學(xué)問也不少,單憑EXPLAIN我們是不能判定該方法是否就是最優(yōu)化的,每個數(shù)據(jù)庫都有自己的一些優(yōu)化器,雖 然可能還不太完善,但是它們都會在查詢時對比過哪種方式較快,在某些情況下,建立索引的話也未必會快,例如索引放在一個不連續(xù)的存儲空間時,這會增加讀磁 盤的負(fù)擔(dān),因此,哪個是最優(yōu),應(yīng)該通過實際的使用環(huán)境來檢驗。
在剛開始的時候,如果表不大,沒有必要作索引,我的意見是在需要的時候才作索引,也可用一些命令來優(yōu)化表,例如MySQL可用"OPTIMIZE TABLE"。
綜上所述,在如何為數(shù)據(jù)庫建立恰當(dāng)?shù)乃饕矫妫銘?yīng)該有一些基本的概念了。

posted on 2012-06-09 15:44 多彩人生 閱讀(453) 評論(0)  編輯 收藏 引用 所屬分類: postgresql

導(dǎo)航

統(tǒng)計

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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ⅴ在线观看| 亚洲欧美国产三级| 亚洲一区视频| 中文精品视频| 亚洲视频免费在线观看| 亚洲欧美国产va在线影院| 先锋影音久久| 欧美18av| 99视频精品全国免费| 亚洲性视频h| 久久久久久精| 欧美激情精品久久久久久黑人| 欧美成人在线网站| 国产精品久久久久久久久久免费看 | 欧美精品在线看| 欧美日韩午夜视频在线观看| 国产精品亚洲аv天堂网| 激情综合在线| 亚洲最新视频在线| 久久精品欧美| 亚洲理论在线观看| 欧美亚洲在线观看| 欧美激情视频一区二区三区免费 | 欧美偷拍另类| 激情久久久久久久久久久久久久久久| 99精品99| 老司机免费视频久久| 亚洲伦理一区| 久久一区二区三区四区五区| 亚洲欧美日韩另类| 欧美成人午夜| 欧美主播一区二区三区美女 久久精品人| 日韩亚洲国产欧美| 美女黄网久久| 亚洲性感美女99在线| 免费中文日韩| 亚洲丰满少妇videoshd| 欧美日韩国产色视频| 国产精品三区www17con| 亚洲精品久久7777| 欧美xxx在线观看| 亚洲制服丝袜在线| 欧美另类极品videosbest最新版本 | 亚洲自拍另类| 欧美日韩亚洲免费| 在线欧美视频| 久久夜色精品国产噜噜av| 亚洲一区制服诱惑| 欧美亚洲成人免费| 亚洲图片激情小说| 亚洲美女视频在线免费观看| 毛片一区二区三区| 在线精品视频一区二区三四| 久久精品三级| 午夜在线观看免费一区| 国产精品久久久久久久久免费| 亚洲国产精品久久久久| 欧美α欧美αv大片| 久久人人超碰| 亚洲人成在线观看| 欧美电影免费观看大全| 久久久久久久久蜜桃| 黑人巨大精品欧美一区二区| 久久在线视频| 久久精品国产999大香线蕉| 国产日韩免费| 麻豆精品视频| 欧美+日本+国产+在线a∨观看| 在线观看欧美日韩国产| 麻豆成人91精品二区三区| 久久免费视频网站| 亚洲乱码一区二区| 亚洲卡通欧美制服中文| 国产精品久久一区主播| 欧美一区二区久久久| 午夜国产精品影院在线观看| 国产一区二区久久| 美女尤物久久精品| 久久久综合激的五月天| 亚洲激情视频在线播放| 亚洲每日在线| 国产精品视频自拍| 久久av红桃一区二区小说| 久久久福利视频| 午夜精品视频在线观看一区二区| 夜色激情一区二区| 亚洲日产国产精品| 亚洲国产欧美日韩另类综合| 欧美www视频在线观看| 一区二区不卡在线视频 午夜欧美不卡'| 亚洲经典三级| 国产精品自拍小视频| 免费亚洲电影| 国产精品igao视频网网址不卡日韩| 午夜精品久久久久久久蜜桃app| 久久成人亚洲| 久久综合色天天久久综合图片| 一本大道久久a久久综合婷婷 | 久久久久在线| 欧美四级在线| 欧美成人一区二免费视频软件| 欧美视频中文一区二区三区在线观看| 久久激情五月激情| 欧美日韩国产精品专区 | 亚洲午夜av电影| 亚洲国产一区在线观看| 亚洲一级在线观看| 亚洲乱码国产乱码精品精 | 亚洲免费av网站| 在线精品一区| 久久国产精品电影| 性欧美大战久久久久久久免费观看 | 亚洲欧美日韩国产一区| 免费成人av在线看| 久久嫩草精品久久久精品| 欧美日韩一区综合| 亚洲国产成人不卡| 极品av少妇一区二区| 亚洲免费一在线| 亚洲午夜小视频| 欧美aⅴ一区二区三区视频| 亚洲欧美日韩在线观看a三区| 欧美韩国日本一区| 欧美电影免费网站| 激情久久中文字幕| 欧美一区二区免费视频| 中文在线不卡视频| 欧美人交a欧美精品| 亚洲国产高清aⅴ视频| 尤物99国产成人精品视频| 中文久久乱码一区二区| 一本色道久久综合狠狠躁篇怎么玩 | 欧美一区二区观看视频| 欧美亚洲综合在线| 欧美色网在线| 牛牛国产精品| 韩日成人在线| 久久精品视频一| 久久久久久一区二区| 国产精品尤物福利片在线观看| 中文在线不卡视频| 欧美在线免费视频| 国产欧美日韩综合一区在线播放| 99re视频这里只有精品| 亚洲国产精品黑人久久久 | 国内精品久久久久久久影视麻豆 | 亚洲国产欧美日韩精品| 亚洲区一区二| 欧美日韩1080p| 一区二区三区四区国产| 亚洲一级片在线看| 国产精品网站在线观看| 性欧美长视频| 美女国内精品自产拍在线播放| 亚洲激情第一页| 欧美午夜久久久| 性欧美长视频| 亚洲电影免费观看高清| 亚洲无亚洲人成网站77777| 国产精品久久久久久久久| 亚洲欧美日韩精品综合在线观看| 欧美亚洲免费电影| 亚洲激情视频在线| 国产精品国产三级国产专播品爱网 | 一区二区三区高清| 欧美日韩国产页| 先锋影音国产一区| 欧美肥婆bbw| 亚洲一区二区免费视频| 国产一区二区三区四区老人| 欧美激情导航| 久久大逼视频| 亚洲人成毛片在线播放| 欧美影院在线播放| 日韩一区二区电影网| 国产美女在线精品免费观看| 久久久久久久一区| 亚洲综合色噜噜狠狠| 亚洲电影在线| 欧美在线一级va免费观看| 亚洲精品日本| 黄色成人免费网站| 国产精品素人视频| 欧美欧美在线| 久久影院午夜论| 亚洲一区一卡| 亚洲精品色婷婷福利天堂| 久久资源在线| 午夜精品视频在线观看| 亚洲精品视频免费| 永久免费视频成人| 国产精品福利在线观看网址| 久久国产日本精品| 亚洲女同同性videoxma| 亚洲精品在线视频观看| 欧美黄色一级视频| 快播亚洲色图| 久久久91精品国产一区二区三区| 在线亚洲成人| 一区二区三区精品在线|