解讀改善SQL Server內(nèi)存管理的問題_Mssql數(shù)據(jù)庫教程
推薦:揭秘SQL Server中刪除重復(fù)數(shù)據(jù)的方法數(shù)據(jù)庫的使用過程中由于程序方面的問題有時候會碰到重復(fù)數(shù)據(jù),重復(fù)數(shù)據(jù)導(dǎo)致了數(shù)據(jù)庫部分設(shè)置不能正確設(shè)置 方法一 以下為引用的內(nèi)容: declare @max integer,@id integer declare cur_rows cursor local for select 主字段,count(*) from 表名 group by 主字
最近,為了能在數(shù)據(jù)庫服務(wù)器中運行其他應(yīng)用程序,在保持數(shù)據(jù)庫操作系統(tǒng)版本不變的前提下對數(shù)據(jù)庫服務(wù)器進行了軟、硬件上的升級。在軟件上,將操作系統(tǒng)從Windows 2000升級到Windows Server 2003;在硬件上,將服務(wù)器中的內(nèi)存由原來的512MB增加到1GB(1024MB)。在升級后的開始幾個星期之內(nèi),服務(wù)器在使用中表現(xiàn)良好。但是不久后就發(fā)現(xiàn),在服務(wù)器上同時運行的其他應(yīng)用程序卻出現(xiàn)了異常,不時地報出內(nèi)存分配不足的警告。經(jīng)過幾次跟蹤后發(fā)現(xiàn),原來是SQL Server吞去了大部分內(nèi)存所致。被SQL Server占用的內(nèi)存由升級前的不到400MB一下子增加到現(xiàn)在的900MB,并且有不斷增長的趨勢。
通過查找原因才知道這是SQL Server 緩沖池的預(yù)期行為。默認情況下,在啟動 SQL Server之后,SQL Server會根據(jù)操作系統(tǒng)報告的物理內(nèi)存數(shù)來動態(tài)增大或縮小高速緩沖存儲器的容量。只要可用物理內(nèi)存大小保持在4MB到10MB之間,SQL Server 緩沖池就會繼續(xù)增大(保留可用物理內(nèi)存在4MB到10MB之間是為了避免操作系統(tǒng)因為缺少內(nèi)存而頻繁地換頁)。如果物理可用內(nèi)存變得較少的時候,則SQL Server會將一些內(nèi)存釋放給操作系統(tǒng)。
為了使運行在服務(wù)器上的應(yīng)用程序都能達到比較滿意的效果,同時也為了能給其他應(yīng)用程序分配足夠的內(nèi)存,需要采取措施限制SQL Server 的內(nèi)存使用量。我們可以通過設(shè)置SQL Server 數(shù)據(jù)庫引擎使用的內(nèi)存的上下限來達到此目的。其具體步驟是:
1.打開企業(yè)管理器,展開服務(wù)器組。
2.單擊該服務(wù)器,點擊鼠標右鍵,單擊屬性菜單。
3.在彈出的對話框中單擊內(nèi)存選項卡。
內(nèi)存設(shè)置方法有兩種:
1.設(shè)置min server memory和max server memory 在一個范圍段內(nèi)。
比如,我們將它設(shè)置成最小0MB,最大255MB。這種方法在為一臺服務(wù)器中運行多個應(yīng)用程序分配內(nèi)存時非常有用。
2.設(shè)置 min server memory 和 max server memory 為同一數(shù)值。
比如,可以將它最大和最小值都設(shè)置成255MB。這樣的設(shè)置方法與窗口中的另一個選項“使用固定的內(nèi)存大小” 相一致。
雖然內(nèi)存最小值和最大值設(shè)置是高級選項,但在設(shè)置完畢之后,最好還是先將SQL Server服務(wù)停止后再重新運行,以便SQL Server能更好地對內(nèi)存進行合理安排。
分享:揭秘Sql語句優(yōu)化注意事項1.盡量不要對列名進行函數(shù)處理。而是針對后面的值進行處理 例如where col1 = -5的效率比where -col1=5的效率要高 因為后面的條件對列值進行了計算。這樣的條件下優(yōu)化器無法使用索引 而是要針對所有值進行計算之后才能再比較 2.盡量使用和數(shù)劇列一樣的值進行
- sql 語句練習(xí)與答案
- 深入C++ string.find()函數(shù)的用法總結(jié)
- SQL Server中刪除重復(fù)數(shù)據(jù)的幾個方法
- sql刪除重復(fù)數(shù)據(jù)的詳細方法
- SQL SERVER 2000安裝教程圖文詳解
- 使用sql server management studio 2008 無法查看數(shù)據(jù)庫,提示 無法為該請求檢索數(shù)據(jù) 錯誤916解決方法
- SQLServer日志清空語句(sql2000,sql2005,sql2008)
- Sql Server 2008完全卸載方法(其他版本類似)
- sql server 2008 不允許保存更改,您所做的更改要求刪除并重新創(chuàng)建以下表
- SQL Server 2008 清空刪除日志文件(瞬間日志變幾M)
- Win7系統(tǒng)安裝MySQL5.5.21圖解教程
- 將DataTable作為存儲過程參數(shù)的用法實例詳解
Mssql數(shù)據(jù)庫教程Rss訂閱編程教程搜索
Mssql數(shù)據(jù)庫教程推薦
- 如何在應(yīng)用環(huán)境中構(gòu)造最優(yōu)的數(shù)據(jù)庫模式
- 解析SQL Server三大算法的I/O成本
- 解析用SQL Server處理物料清單規(guī)則
- SQL Server 2008 清空刪除日志文件(瞬間日志變幾M)
- 解讀Oracle數(shù)據(jù)庫SQL語句性能調(diào)整的基本原則
- 解析使用 SQL Server 數(shù)據(jù)庫查詢累計值的方法
- SQL Server 索引基礎(chǔ)知識(4)----主鍵與聚集索引
- SQL Server 2008網(wǎng)絡(luò)協(xié)議深入理解
- 如何解決DB2中出現(xiàn)的SQL1032N錯誤現(xiàn)象
- 安裝sqlserver2000時出現(xiàn)wowexec.exe無反應(yīng)的解決方法
猜你也喜歡看這些
- 相關(guān)鏈接:
- 教程說明:
Mssql數(shù)據(jù)庫教程-解讀改善SQL Server內(nèi)存管理的問題
。