国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

怎么清除sql server日志

2024-08-31 00:48:40
字體:
來源:轉載
供稿:網友

方法1:
第一步:
backup log database_name with no_log
或者 backup log database_name with truncate_only --no_log和truncate_only是在這里是同義的,隨便執行哪一句都可以
第二步:
1.收縮特定數據庫的所有數據和日志文件,執行 dbcc shrinkdatabase (database_name,[,target_percent])--database_name是要收縮的數據庫名稱;target_percent是數據庫收縮后的數據庫文件中所要的剩余可用空間百分比
2.收縮一次一個特定數據庫中的數據或日志文件,執行 dbcc shrinkfile(file_id,[,target_size]) --file_id是要收縮的文件的標識 (id) 號,若要獲得文件 id,請使用 file_id 函數或在當前數據庫中搜索 sysfiles;target_size是用兆字節表示的所要的文件大小(用整數表示)。如果沒有指定,dbcc shrinkfile 將文件大小減少到默認文件大小

兩個dbcc都可以帶上參數notruncate或truncateonly,具體意思看幫助。


方法2(這個方法在sqlserver2000的環境下做一般能成功,在sqlserver7及以下版本就不一定了):
第一步:
先備份整個數據庫以備不測
第二步:
備份結束后,在query analyzer中執行如下的語句:
exec sp_detach_db yourdbname,true --卸除這個db在mssql中的注冊信息
第三步:
到日志的物理文件所在的目錄中去刪除該日志文件或者將該日志文件移出該目錄
第四步:
在query analyzer中執行如下的語句:
exec sp_attach_single_file_db yourdbname,'d:/mssql7/data/yourdbname_data.mdf'
--以單文件的方式注冊該db,如果成功則mssql將自動為這個db生成一個500k的日志文件。

以上方法在清除log日志中均有效。
但,能否讓sql server 不產生log日志呢?以上方法好像均無效。
我這兒正好有個case:
我客戶的sql server每天都會產生4,500m的log日志,每天都清除一下,非常不便。有沒有辦法實現不產生log日志呢?

我分析了一下客戶產生log日志的原因,并且做了相應測試。
客戶是每天將數據庫清空,從總系統中將數據導入到sql server里。我感決sqlserver在插入時產生log不大,在delete整個庫時產生log極大。
比如:
select * into test_2 from b_bgxx
共45000條記錄,產生十幾m log,如果
delete from test_2
產生80多m log ,這明顯存在問題。

雖然可以換成:
truncate table test_2
但我還是希望能找到不產生log的方法。就如oracle不產生歸檔一樣。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 许昌市| 霍林郭勒市| 大厂| 鞍山市| 旅游| 会泽县| 丽江市| 墨脱县| 江北区| 临潭县| 措美县| 柳河县| 莲花县| 黄骅市| 扶沟县| 于田县| 安塞县| 定南县| 白沙| 惠东县| 长宁区| 渭源县| 全州县| 渝北区| 屯门区| 万载县| 巴青县| 兴安盟| 青川县| 柞水县| 盘锦市| 启东市| 天镇县| 伊金霍洛旗| 崇信县| 隆昌县| 双峰县| 土默特右旗| 安溪县| 桃源县| 龙州县|