當前位置:ag真人国际官网-ag旗舰厅官方网站 » 編程語言 » sqlserver提高

sqlserver提高-ag真人国际官网

發布時間: 2024-11-15 15:24:40

❶ 如何提高sql server大數據條件下的查詢速度

1.關於索引優化
建索引的選擇必須結合sql查詢、修改、刪除語句的需要,一般的說法是在where里經常出現的欄位建索引。如果在where經常是幾個欄位一起出現而且是用and連接的,那就應該建這幾個欄位一起的聯合索引,而且次序也需要考慮,一般是最常出現的放前面,重復率低的放前面。
sql
server提供了一種簡化並自動維護資料庫的工具。這個稱之為資料庫維護計劃向導(database
maintenance
plan
wizard
,dmpw)的工具也包括了對索引的優化。如果你運行這個向導,你會看到關於資料庫中關於索引的統計量,這些統計量作為日誌工作並定時更新,這樣就減輕了手工重建索引或者dbcc
indexdefrag所帶來的工作量。如果你不想自動定期刷新索引統計量,你還可以在dmpw中選擇重新組織數據和數據頁,這將停止舊有索引並按特定的填充因子重建索引。
2.
改善硬體(雙cpu,raid
5,增加內存)
tempdb這個臨時資料庫,它對性能的影響較大。tempdb和其他資料庫一樣可以增大,可以縮小。當數據文件需要增長的時候,通常不能保持剩餘部分的連續性。這時文件就會產生碎片,這種碎片會造成性能下降。這種碎片屬於外來性碎片。要阻止在tempdb中產生外來性碎片,必須保證有足夠的硬碟空間。一般將tempdb的容量放到平均使用容量。而你也應該允許tempdb自動增長,比如你有個一個超大的join操作,它建立了一個超過tempdb容量的時候,該查詢將失敗。你還要設置一個合理的單位增長量。因為如果你設得太小,將會產生許多外來性碎片,反而會佔用更多資源。sqlserver調優最有效的做法之一,就是把爭奪資源的操作獨立出去。tempdb就是一個需要獨立出去的部分而tempdb和其他系統庫一樣是公用的,是存取最可能頻繁的庫,所有處理臨時表、子查詢、group
by、排序、distinct、連接等等。它最適合放到一個具有快速讀寫能力的設備上。比如raid0卷或raid0 1卷上。
查詢語句一定要使用存儲過程;
3、查詢盡量使用top子句
4.將表按一定的約束分成子表,(如按分類)創建約束,在用like
時,先用分類
and
like
,
應該可能解決問題.
而且效果立稈見影!(你要確定sql會認識你建的分區視圖).我一個表有上百萬的記錄(700兆),用分區視圖後,查詢速度基本跟10萬行一樣.
如果還是太慢,還可以考濾分布式分區視圖!這總可以解決問題了吧!
關鍵在於你能否把大表按某種約束分解成子表.

熱點內容
vb資料庫數組 發布:2024-11-19 09:23:40 瀏覽:827
安卓游戲數據保存在哪裡找 發布:2024-11-19 09:22:02 瀏覽:309
解壓出來的文件亂碼 發布:2024-11-19 09:15:40 瀏覽:939
北航ftp是多少 發布:2024-11-19 09:15:32 瀏覽:821
瀏覽保存密碼如何取消 發布:2024-11-19 09:10:17 瀏覽:89
安卓怎麼關簡訊重復提醒 發布:2024-11-19 09:02:00 瀏覽:635
html與php的區別 發布:2024-11-19 09:00:53 瀏覽:193
晚安密碼多少 發布:2024-11-19 09:00:51 瀏覽:945
易語言腳本模塊 發布:2024-11-19 09:00:44 瀏覽:484
經典矩陣c語言 發布:2024-11-19 08:56:23 瀏覽:268
网站地图