網絡服務器軟件開發/中間件開發,關注ACE/ICE/boost
C++博客
首頁
新隨筆
聯系
聚合
管理
152 Posts :: 3 Stories :: 172 Comments :: 0 Trackbacks
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
(18)
給我留言
查看公開留言
查看私人留言
隨筆分類
ACE(12)
boost(6)
C++基礎(20)
CORBA(4)
Design Pattern(1)
ebook(1)
ICE(7)
java(1)
linux(28)
mysql(15)
PHP(1)
python(6)
RakNet(1)
SQLite
STL(1)
VC/MFC/.NET(4)
辦公技巧(5)
編碼知識(8)
創意&想法(2)
開發感想(12)
理財(2)
其它開源庫(13)
生活感想(23)
數據結構算法(1)
通信技術(8)
網絡服務器開發(9)
游戲開發(4)
隨筆檔案
2012年7月 (1)
2011年9月 (1)
2011年8月 (1)
2011年5月 (2)
2011年4月 (1)
2011年1月 (9)
2010年12月 (6)
2010年11月 (1)
2010年10月 (3)
2010年9月 (12)
2010年8月 (7)
2010年7月 (1)
2009年10月 (2)
2009年9月 (3)
2009年8月 (1)
2009年3月 (1)
2009年2月 (5)
2009年1月 (6)
2008年12月 (2)
2008年11月 (1)
2008年10月 (1)
2008年9月 (1)
2008年7月 (9)
2008年6月 (10)
2008年5月 (13)
2008年4月 (2)
2008年3月 (3)
2008年1月 (1)
2007年11月 (5)
2007年9月 (1)
2007年8月 (5)
2007年7月 (3)
2007年6月 (2)
2007年5月 (4)
2007年4月 (20)
2007年3月 (6)
文章分類
設計模式
文章檔案
2007年3月 (3)
好友博客
LOGOS
搜索
積分與排名
積分 - 237569
排名 - 107
最新評論
1.?re: C++實現的MD5算法
你這代碼功底也夠爛了,你多測試幾次,內存嘩嘩的流...
--熱心網頁
2.?re: std::queue的front的問題[未登錄]
在c++中int并不是類,沒有析構,是值拷貝。
你換std::string試試,準掛。
--星爺
3.?re: mysql下如何執行sql腳本【轉】[未登錄]
Thanks!
--me
4.?re: ldconfig幾個需要注意的地方 zhuan
學習了,收藏
--thebye85
5.?re: 體驗RakNet的RPC3
評論內容較長,點擊標題查看
--雅歌
閱讀排行榜
1.?mysql下如何執行sql腳本【轉】(15019)
2.?怪異的boost,fatal error LNK1104: 無法打開文件“libboost_system-vc80-mt-gd-1_35.lib”(11468)
3.?boost interprocess之message queue(7128)
4.?【ZT】ADSL大型技術專題(圖文)(6927)
5.?VOIP開源項目源碼地址(二) ---[voip涉及到的所有的資料]【轉帖】(5447)
評論排行榜
1.?Buffer類就應該簡單,直觀(16)
2.?怪異的boost,fatal error LNK1104: 無法打開文件“libboost_system-vc80-mt-gd-1_35.lib”(13)
3.?自己造的一個線程類(12)
4.?對基本類型的再包裝,方便了移植(12)
5.?游戲害慘了我多少同學(10)
mysql中在not in后面慎用 select子查詢 及臨時表的使用
有個存儲過程,功能是:根據用戶名查詢非好友的ID,代碼如下:
begin
select UserID from Users
where
UserID
!=
pUserID and
Users.UserID not
in
(
select FriendID from Users_Friend where Users_Friend.UserID
=
pUserID and DeleteFlag
=
0
)
and
Users.Name like BINARY concat(
'
%
'
,pUserName,
'
%
'
) ;
end
其中,pUserID是搜索者的UID,pUserName是要搜索的用戶名。今天發現這個存儲過程非常慢,分析結論是:not in 后面的select子查詢是每次都執行的,這出乎意料!mysql難道不能優化掉這樣的查詢嗎?
后來用了臨時表的方案,如下:
begin
Create TEMPORARY Table IF NOT EXISTS temp(FriendID
int
);
insert into temp(FriendID) select FriendID from Users_Friend where Users_Friend.UserID
=
pUserID and DeleteFlag
=
0
;
select UserID from Users
where
UserID
!=
pUserID and
Users.UserID not
in
(
select FriendID from temp
)
and
Users.Name like BINARY concat(
'
%
'
,pUserName,
'
%
'
) ;
drop TEMPORARY table temp;
end
問題較好的解決了,因為臨時表temp中保存的都是好友的ID,非常快,不用每次都去執行好友的篩選邏輯。另外一種方式是:將好友ID作為參數傳遞到存儲過程中,在程序外面查詢好友,但要改動程序。
posted on 2011-01-13 13:05
true
閱讀(2967)
評論(0)
編輯
收藏
引用
所屬分類:
mysql
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
mysql的加密函數
使用微軟企業庫連接mysql碰到的奇怪問題
mysql將查詢結果保存到文件
mysql中在not in后面慎用 select子查詢 及臨時表的使用
mysql的unix時間戳
mysql存儲過程中使用事務
轉自群里面的討論sql語句:varbinary類型,取某連續幾個字節,排序
mysql自動備份腳本
mysql存儲過程事務執行過程中出現異?;貪L機制
360竟會自動關閉mysql
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © true
国产亚洲欧美精品久久久
|
伊人色综合久久
|
久久一区二区免费播放
|
无码乱码观看精品久久
|
亚洲中文字幕久久精品无码喷水
|
久久国产热精品波多野结衣AV
|
99久久婷婷国产一区二区
|
日韩va亚洲va欧美va久久
|
国产精品久久毛片完整版
|
四虎国产精品成人免费久久
|
久久九九亚洲精品
|
亚洲国产精品无码久久久秋霞2
|
观看 国产综合久久久久鬼色 欧美 亚洲 一区二区
|
久久ww精品w免费人成
|
99热热久久这里只有精品68
|
无码日韩人妻精品久久蜜桃
|
久久艹国产
|
狠狠人妻久久久久久综合
|
久久久久人妻一区二区三区vr
|
中文成人久久久久影院免费观看
|
久久精品www
|
99久久精品毛片免费播放
|
亚洲精品无码久久久久
|
久久天天躁狠狠躁夜夜av浪潮
|
久久久国产精品网站
|
精品人妻久久久久久888
|
狠狠综合久久AV一区二区三区
|
伊人久久成人成综合网222
|
国产ww久久久久久久久久
|
97久久精品人人澡人人爽
|
久久香蕉国产线看观看乱码
|
俺来也俺去啦久久综合网
|
国产∨亚洲V天堂无码久久久
|
久久水蜜桃亚洲av无码精品麻豆
|
色综合久久久久无码专区
|
亚洲AV乱码久久精品蜜桃
|
丁香色欲久久久久久综合网
|
色婷婷综合久久久久中文
|
久久精品99久久香蕉国产色戒
|
国内精品久久久久久99蜜桃
|
久久久久亚洲AV无码永不
|