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

colorful

zc qq:1337220912

 

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

最普通的情況,是為出現(xiàn)在where子句的字段建一個(gè)索引。為方便講述,我們先建立一個(gè)如下的表。
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
);
如果你在查詢(xún)時(shí)常用類(lèi)似以下的語(yǔ)句:
 SELECT * FROM mytable WHERE category_id=1;
最直接的應(yīng)對(duì)之道,是為category_id建立一個(gè)簡(jiǎn)單的索引:
 CREATE INDEX mytable_categoryid
 ON mytable (category_id);
OK.如果你有不止一個(gè)選擇條件呢?例如:
 SELECT * FROM mytable WHERE category_id=1 AND user_id=2;
你的第一反應(yīng)可能是,再給user_id建立一個(gè)索引。不好,這不是一個(gè)最佳的方法。你可以建立多重的索引。
CREATE INDEX mytable_categoryid_userid ON mytable (category_id,user_id);
注意到我在命名時(shí)的習(xí)慣了嗎?我使用"表名_字段1名_字段2名"的方式。你很快就會(huì)知道我為什么這樣做了。
現(xiàn)在你已經(jīng)為適當(dāng)?shù)淖侄谓⒘怂饕贿^(guò),還是有點(diǎn)不放心吧,你可能會(huì)問(wèn),數(shù)據(jù)庫(kù)會(huì)真正用到這些索引嗎?測(cè)試一下就OK,對(duì)于大多數(shù)的數(shù)據(jù)庫(kù)來(lái)說(shuō),這是很容易的,只要使用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ù)庫(kù)在查詢(xún)的時(shí)候使用了一個(gè)索引(一個(gè)好開(kāi)始),而且它使用的是我創(chuàng)建的第二個(gè)索引。看到我上面命名的好處了吧,你馬上知道它使用適當(dāng)?shù)乃饕恕?/p>

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

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

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

導(dǎo)航

統(tǒng)計(jì)

常用鏈接

留言簿(3)

隨筆分類(lèi)

隨筆檔案

搜索

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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久久极品少妇xxxxⅹ软件| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美一级一区| 欧美1区视频| 国产精品99久久久久久人| 欧美一区二区三区视频在线观看 | 韩国女主播一区| 99re6热只有精品免费观看 | 久久久久一区二区三区| 亚洲国产裸拍裸体视频在线观看乱了中文| 亚洲麻豆av| 裸体一区二区| 国产精品亚洲精品| 亚洲精品久久久一区二区三区| 亚洲在线视频网站| 亚洲大片精品永久免费| 欧美亚洲综合久久| 欧美肉体xxxx裸体137大胆| 好吊色欧美一区二区三区视频| 一区二区高清视频| 欧美电影美腿模特1979在线看| 久久精品欧洲| 国产精品视频xxxx| 亚洲精品国精品久久99热一| 性欧美8khd高清极品| 日韩视频一区二区三区在线播放| 久久av红桃一区二区小说| 国产精品久久久久久久久动漫| 亚洲人体1000| 欧美国产日韩精品免费观看| 香蕉成人伊视频在线观看| 欧美日韩免费看| 亚洲美女在线看| 欧美国产日韩a欧美在线观看| 欧美一级网站| 国产精品一区二区你懂得| 国产精品99久久久久久有的能看| 欧美成人自拍视频| 久久免费少妇高潮久久精品99| 国产精品一区二区久久久| 亚洲一区精品在线| 一本一道久久综合狠狠老精东影业 | 亚洲欧美日韩国产精品| 欧美午夜精品久久久久久浪潮| 亚洲精品中文字幕女同| 麻豆精品一区二区综合av| 欧美亚洲尤物久久| 国模私拍一区二区三区| 老色鬼久久亚洲一区二区| 久久精品在这里| 亚洲成人在线视频播放| 免费成人av在线| 久久综合99re88久久爱| 亚洲国产精品www| 亚洲福利视频一区| 欧美美女视频| 亚洲影视中文字幕| 午夜精品久久久久久久久久久 | 国产午夜精品视频| 久久精品国产一区二区三区| 先锋影音国产一区| 亚洲第一网站免费视频| 欧美国产专区| 欧美日韩在线精品一区二区三区| 亚洲欧美激情视频| 欧美伊人精品成人久久综合97| 精品成人一区| 亚洲精品欧美一区二区三区| 欧美四级剧情无删版影片| 欧美亚洲一区在线| 另类图片国产| 亚洲免费在线精品一区| 久久精品国产99| 日韩亚洲欧美成人| 亚洲欧美日韩国产综合| 亚洲激情影视| 欧美国产国产综合| 国产精品大片| 免费亚洲婷婷| 国产精品看片你懂得| 免费在线一区二区| 欧美视频观看一区| 蜜桃久久av一区| 欧美丝袜一区二区| 欧美国产日韩精品| 国产日韩精品在线播放| 亚洲日本欧美| 精品不卡在线| 中文国产成人精品久久一| 伊人婷婷久久| 亚洲欧美日韩在线高清直播| 亚洲三级观看| 久久精品国产亚洲精品| 亚洲一区国产| 欧美精品成人91久久久久久久| 久久激情中文| 国产精品美女久久久浪潮软件| 欧美gay视频激情| 国产伦精品一区二区三区| 亚洲美女少妇无套啪啪呻吟| 精品88久久久久88久久久| 中文日韩电影网站| 日韩视频中午一区| 久久夜色精品国产欧美乱极品| 午夜一级久久| 国产精品高潮久久| 亚洲精品一级| 日韩一级二级三级| 欧美韩日一区二区| 欧美成人四级电影| 国产综合亚洲精品一区二| 亚洲欧美日韩中文在线制服| 亚洲色无码播放| 欧美日韩精品免费观看| 亚洲精品视频免费| 一本色道久久综合一区| 欧美激情在线播放| 亚洲黄色片网站| 一区二区免费在线播放| 欧美人妖另类| 一区二区精品国产| 亚洲一区二区三区精品在线| 欧美色图五月天| 亚洲午夜免费视频| 欧美一级久久久| 国产一区二区三区电影在线观看| 亚洲欧美另类中文字幕| 欧美一区观看| 国产一区二区在线观看免费播放| 午夜精品视频在线观看| 亚洲欧美激情在线视频| 国产精品国产三级国产aⅴ9色| 亚洲一区二区三区四区在线观看| 亚洲欧美一区二区视频| 国产区日韩欧美| 久久久精品免费视频| 欧美激情a∨在线视频播放| 亚洲精品乱码久久久久久黑人| 欧美日韩爆操| 午夜在线精品偷拍| 欧美wwwwww| 99亚洲视频| 国产伦精品一区二区三区在线观看| 午夜精品久久久久久久99水蜜桃 | 免费成人高清| 91久久国产综合久久蜜月精品| 性久久久久久久| 久久久久久久999精品视频| 一区视频在线| 欧美日韩蜜桃| 欧美一区二区播放| 欧美激情麻豆| 欧美一级视频精品观看| 亚洲国产欧美日韩| 国产精品久久久久久久浪潮网站| 午夜精品在线| 亚洲激情第一页| 久久动漫亚洲| 一本色道久久综合亚洲91| 国产婷婷色综合av蜜臀av| 欧美成人精精品一区二区频| 一区二区三区欧美成人| 欧美成人免费在线观看| 午夜精品福利一区二区蜜股av| 在线视频成人| 国产欧美日韩精品专区| 欧美激情视频给我| 久久精品视频导航| 一区二区三区国产精品| 亚洲电影有码| 久久蜜桃资源一区二区老牛 | 一本色道久久综合狠狠躁的推荐| 欧美在线一级va免费观看| 亚洲久久成人| 伊人久久大香线蕉综合热线| 国产精品高潮久久| 欧美日韩国产系列| 欧美成人资源| 麻豆国产va免费精品高清在线| 亚洲欧美在线免费| 一区二区国产精品| 亚洲精品一区二区三区蜜桃久|