亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

在數據量和訪問量劇增條件下保持數據庫效率

2024-07-21 02:44:29
字體:
來源:轉載
供稿:網友

在某些網站里,你可以訂閱好友,這樣,好友發的消息就會出現在你的主頁里,這種方式確實很人性化,但是就引出了一個疑問,他們應該如何組織數據庫才能在很大的數據量和訪問量下效率最高呢?

首先,數據庫應該是這樣的:(括號里是字段,其他無關信息省略)

用戶表:user (uid, name), uid為主鍵。

信息表:msg (mid, uid, content), mid為主鍵,uid為發貼人。

好友表:friend (uid, fid), uid為主人,fid為好友(即uid訂閱的人的id)。

這樣,要查詢出某人的所有好友的信息就可以這樣寫SQL語句:(已查詢uid=1的為例)

1) SELECT * FROM msg, friend WHERE msg.uid=friend.fid AND friend.fid=1;

注意:千萬不要寫成:

2) SELECT * FROM msg WHERE uid IN (SELECT fid FROM friend WHERE uid=1);

子查詢的方法比級聯兩張表慢了不止1個數量級!

(測試結果,方法1)能在10-30ms查詢出結果,而方法2)則用了3min還沒有出來結果)


有些人在網上說再增加一張中介表可以提高速度:

中介表:linker (uid, mid)

中介表是這樣用的,每次當一個人發了一篇帖子,則將所有訂閱他的人(uid)和這篇帖子的mid插入中介表里,例如,uid=1的人有3個訂閱者,分別為:2、3、4,則當uid=1的人發了一篇帖子mid=100時,就應往linker表里插入這些數據:(2, 100), (3, 100), (4, 100)。這樣,對一個uid而言,linker表和msg表就形成了一對一的關系。查詢的時候,只需級聯linker表和msg表就行了,如下:(還是以查uid=1的為例)

3) SELECT * FROM msg, linker WHERE msg.mid=linker.mid and linker.uid=1;

這樣乍看好像比1)要快一些,因為就一個uid而言linker表和msg表是一對一的關系,而方法1)的卻是一對多的關系。而且,有些人認為,就算不這么看,因為方法3)在插入時比方法1)多做了很多操作,所以查詢的速度應該能比方法1)快,至少不會比方法1)慢。


我實際測試下來的結果是,方法3)比方法1)慢了至少1倍的時間,而且數據量越大,慢得就越多。測試結果:

a) user有10,000條,friend有160,000條,msg有80,000條時:平均查詢時間:

方法1)是:0.04s,方法3)是0.08s,3)比1)慢1倍。

b) 當msg有260,000條時:方法1)是:0.18s,方法3)是:0.70s,3)比1)慢3倍。

(以上結果都是在建了索引之后的)


根據分析,3)比1)慢的原因,主要是當數據增大時,linker表的數據量急劇增大所致。因為當msg里有260,000條數據是,linker表的數據量已經超過4,000,000條了。


通過對這個的研究得出幾點體會:

◆1、數據庫對where的優化做得太好了(除了"in"關鍵字)。

◆2、索引對數據查詢效率的影響是太大了,我開始測試的時候沒有建索引,查詢時間都在幾百毫米,建了以后降低到幾十毫米了。

◆3、不要隨便相信網上的一些討論,要通過自己學過的知識去驗證網上討論的對錯。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97人人爽人人喊人人模波多| 中文字幕亚洲欧美一区二区三区| 精品国产乱码久久久久久虫虫漫画| 狠狠久久亚洲欧美专区| 精品国产电影一区| 国产精品久久久久久久久久东京| 欧洲精品毛片网站| 国产精品一区二区在线| 欧美电影第一页| 热99在线视频| 欧美日韩国产成人| 欧美激情一区二区久久久| 亚洲国产成人久久综合一区| 7m第一福利500精品视频| 久久精品亚洲一区| 久久人人爽人人爽人人片av高清| 精品丝袜一区二区三区| 国产成人免费91av在线| 日韩欧美极品在线观看| 色综合视频一区中文字幕| 国产精品91久久| 日韩欧美视频一区二区三区| 日韩高清免费在线| 97视频国产在线| 中国日韩欧美久久久久久久久| 精品伊人久久97| 91热福利电影| 欧美国产激情18| 亚洲成人xxx| 亚洲人成网站色ww在线| 亚洲2020天天堂在线观看| 91免费精品视频| 成人福利网站在线观看| 成人欧美在线观看| 国产精品电影在线观看| 国内精品在线一区| 高潮白浆女日韩av免费看| 日韩在线视频线视频免费网站| 日韩欧美国产中文字幕| 国产一区二区精品丝袜| 国产欧美中文字幕| 91免费人成网站在线观看18| 久久久电影免费观看完整版| 国产成人精品视| 清纯唯美亚洲激情| 91网站在线看| 亚洲欧美精品中文字幕在线| 亚洲天堂影视av| 欧美激情国产高清| 久久久电影免费观看完整版| 在线视频欧美日韩| 日韩网站在线观看| 永久免费精品影视网站| 青青久久av北条麻妃黑人| 国产午夜精品久久久| 国产在线高清精品| 亚洲天堂免费观看| 日韩欧美中文字幕在线播放| 欧美一级淫片aaaaaaa视频| 亚洲欧美日韩中文视频| 欧美性生交大片免费| 久久久91精品| 最近中文字幕日韩精品| 91欧美日韩一区| 亚洲iv一区二区三区| 97久久久免费福利网址| 久久视频中文字幕| 成人看片人aa| 45www国产精品网站| 亚洲日韩中文字幕| 91在线色戒在线| 国产精品视频午夜| 国产精品日韩在线观看| 日韩视频免费在线| 国产综合久久久久久| 日韩欧美中文字幕在线观看| 亚洲3p在线观看| 色阁综合伊人av| 亚洲国产精品人人爽夜夜爽| 国产精品亚洲美女av网站| 欧美中文字幕在线观看| 亚洲色无码播放| 久久69精品久久久久久久电影好| 国产成人精品网站| 日韩欧美a级成人黄色| 国产+成+人+亚洲欧洲| 久久人人看视频| 久久久久久久久久久久久久久久久久av| 亚洲乱码一区av黑人高潮| 91精品国产91久久久久久| 欧美一区二区三区免费视| 精品国产福利视频| 欧美超级乱淫片喷水| 97免费视频在线播放| 欧美精品成人91久久久久久久| 爽爽爽爽爽爽爽成人免费观看| 久久精品夜夜夜夜夜久久| 高清欧美一区二区三区| 久久精品国产v日韩v亚洲| www.日韩av.com| 国产精品激情自拍| 欧美性视频在线| 欧美激情视频免费观看| 成人免费淫片aa视频免费| 91精品视频在线播放| 欧美成人精品在线播放| 亚洲电影免费观看高清完整版| 91视频国产精品| 久久人人爽人人爽人人片亚洲| 欧美日韩xxx| 亚洲国产精品久久久久秋霞蜜臀| 午夜精品福利电影| 91精品国产高清| 欧美人与性动交a欧美精品| 久久久av一区| 最近中文字幕mv在线一区二区三区四区| 久久久久成人精品| 欧美日韩高清区| 日韩欧美在线视频| 国产91热爆ts人妖在线| 清纯唯美亚洲激情| 欧美大片在线看免费观看| 另类美女黄大片| 青青草一区二区| 亚洲欧洲在线观看| 91在线观看免费观看| 最近2019年手机中文字幕| 国产欧美久久一区二区| 亚洲精品一区二区在线| 美女福利精品视频| 国产小视频国产精品| 亚洲成人免费在线视频| 欧美成人黄色小视频| 日韩免费av一区二区| 91在线色戒在线| 亚洲精品综合久久中文字幕| 亚洲精品乱码久久久久久按摩观| 亚洲午夜未满十八勿入免费观看全集| 精品自拍视频在线观看| 国产日韩精品入口| 欧美激情在线视频二区| 中文日韩电影网站| 日韩精品视频在线免费观看| 爽爽爽爽爽爽爽成人免费观看| 精品福利免费观看| 国产精品永久免费在线| 久久精品视频在线播放| 精品久久久中文| 精品久久中文字幕久久av| 亚洲国产精品高清久久久| 亚洲欧美日韩图片| 亚洲日韩中文字幕在线播放| 国产美女久久精品| 国产精品高潮呻吟久久av黑人| 亚洲最大的网站| 国产精品影院在线观看| 亚洲精品成a人在线观看| 欧美性猛交xxxx黑人| 97精品国产97久久久久久春色| 91麻豆国产语对白在线观看| 精品福利视频导航| 国产精品一二三视频| 中国人与牲禽动交精品| 亚洲精品电影在线观看|