導航:首頁 > 編程大全 > oracle資料庫count函數

oracle資料庫count函數

發布時間:2024-09-15 22:01:03

① 在oracle生產庫中,我的一個表的數據有10億行記錄,怎麼快速計算有多少行,不要告訴我用count(*)之類的答案

你的這個表有主鍵沒?
如果有主鍵,假設你的這個表的主鍵是sid
那麼可以使用
select count(sid) from tablename
來查詢會比你用count(*) 要快的多。使用主鍵欄位會用到主鍵索引,會比你去掃描整個表要快的多。
oracle 裡面統計某個表的數據行的數量只有使用count函數來求。如果數據量非常大你應該考慮把你的歷史數據給清理掉或者使用分區表 。

② oracle資料庫,搜索百萬級別數據分頁優化問題

oracle count 百萬級 分頁查詢記錄總數、總條數優化
Oracle count 百萬級 查詢記錄總數、總條數優化
最近做一個項目時,做分頁時,發現分頁查詢速度很慢,分頁我做的是兩次查詢,一次是查詢總數,一次是查詢分頁結果
[java] view plain
/** 查詢總記錄數 **/
SELECT
COUNT(id)
FROM
USER
order by
id
/** 查詢結果集 **/
select
*
from
( select
row_.*,
rownum rownum_
from
( select
id ,
user_number,
user_name,
user_password,
sex,
Registered_time,
last_login_time,
post
from
USER u
order by
u.id) row_
where
rownum <= ?
)
where
rownum_ > ?
user表中的記錄是128萬多條,這個是沒有查詢條件時的查詢,也就是用戶剛剛進入模塊時的查詢,發現查詢時間是2566ms~2152ms之間,單獨執行每條語句,發現第一條的執行時間在2000ms以上,在PL/SQL中執行的結果也證實了我的判斷。所以要對select count語句進行優化。
在網上找了很多優化方案,大多不盡人意,(分表的方式聽上去不錯,不過由於單表是歷史原因,這里就不作考慮)。最後找到一個比較令人滿意的答。就是在語句中加入 /*+ROWID(USER)*/或者/*+ INDEX(USER ID) */ 來提高查詢效果。
聽說這個就是強制使用索引統計結果?如果有哪位大蝦能把原理詳細告訴我,請來多多指點!
[java] view plain
SELECT /*+ROWID(USER)*/ count(*) FROM USER t
或者
SELECT /*+ INDEX(USER ID) */ count(*) FROM USER t
使用後,單條統計總數的查詢在800ms左右,分頁查詢結果基本在900ms~950ms之間,基本在一秒之內,達到了當初設計需求。
當然,這個是沒有加查詢條件的,當把查詢條件加入後,不管前面加不加強制索引,結果時間都在2000ms之間,所以,如果要進行有條件的查詢,就要在where條件中進行優化。特別注意條件欄位查詢前後順序。

閱讀全文

與oracle資料庫count函數相關的資料

熱點內容
陌陌科技旗下有哪些app 瀏覽:521
linux內網映射到外網 瀏覽:430
魅族相機程序 瀏覽:630
iphone6剛買來就有點彎 瀏覽:618
升級ios9滑動來升級 瀏覽:341
應用寶上傳安卓和蘋果手機助手 瀏覽:590
win10創建恢復盤 瀏覽:453
女神投票網站 瀏覽:211
灰灰影視網站多少 瀏覽:730
給文件夾漏溝 瀏覽:164
聯系伺服器默認密碼 瀏覽:980
chm文件怎麼轉換成pdf 瀏覽:988
javasetup6u22exe 瀏覽:692
win10rdpusb重定向 瀏覽:183
郵箱怎麼傳送文件夾嗎 瀏覽:518
蘋果app怎麼恢復購買 瀏覽:929
聯想光碟驅動程序下載 瀏覽:151
文件管理器一次分享多個圖片 瀏覽:819
管家婆銷售單樣式默認哪個文件夾 瀏覽:2
為什麼待機時數據網路斷開 瀏覽:161

友情鏈接