西西软件园多重安全检测下载网站、值得信赖的软件下载站!
软件
软件
文章
搜索

首页西西教程数据库教程 → 删除sqlserver数据库日志文件和附加没有日志文件的数据库解决办法

删除sqlserver数据库日志文件和附加没有日志文件的数据库解决办法

相关软件相关文章发表评论 来源:西西整理时间:2014/6/4 10:21:25字体大小:A-A+

作者:西西点击:721次评论:0次标签: sqlserver

  • 类型:数据库类大小:594KB语言:中文 评分:7.7
  • 标签:
立即下载

删除数据库日志文件的方法

你曾经有在执行SQL的时候,数据库报事务日志已满,然后执行报错。然后纠结于怎么删除数据库日志,捣鼓半天吗,现在就提供两种删除日志文件的方法,希望能够帮到你!

方法一:手工操作

1.数据库->右键->属性->选项-恢复模式->由完成切换成简单

2.数据库->右键->任务->收缩-文件->由完成切换成简单->文件类型->日志->将文件收缩到

方法二:存储过程代替手工操作


    --日志文件收缩至多少M
    DECLARE @DBLogSise AS INT
    SET @DBLogSise=0
    --查询出数据库对应的日志文件名称
    DECLARE @strDBName AS NVARCHAR(500)    DECLARE @strLogName AS NVARCHAR(500)    DECLARE @strSQL AS VARCHAR(1000)    
    SELECT 
        @strLogName=B.name,        @strDBName=A.name    FROM master.sys.databases AS A    INNER JOIN sys.master_files AS B    ON A.database_id = B.database_id    WHERE A.database_id=DB_ID() 
        
    SET @strSQL='
    --设置数据库恢复模式为简单
    ALTER DATABASE ['+@strDBName+'] SET RECOVERY SIMPLE;
    --收缩日志文件
    DBCC SHRINKFILE ('''+@strLogName+''' , '+CONVERT(VARCHAR(20),@DBLogSise)+');
    --恢复数据库还原模式为完整
    ALTER DATABASE ['+@strDBName+'] SET RECOVERY FULL '
    exec(@strSQL)



1.在数据库中执行上面的存储过程

2.然后再执行 EXEC dbo.usp_p_delDBLog @DBLogSise = 0 (收缩至多少M)

回到顶部

示例存储过程下载

usp_p_delDBLog.sql

附加没有日志文件的数据库方法

今天客户那边执行SQL报错,经查看是客户服务器数据库磁盘已被全部用完,日志文件达到500GB的程度,后来由于我的错误操作导致日志文件(.ldf)被删除,后来附加.mdf文件老是说没有日志文件附加不成功,后来经过一番折腾终于解决了,下面分享一下!

操作步骤

1.新建同名的数据库文件

2.暂停SQLSetver服务

3.将原先的mdf文件,覆盖新建的数据库,删除新数据库的ldf文件

4.重新启动SQLSetver服务 ,这时看到的数据库是这个样子的,打不开

  

5.执行以下SQL语句


 1 --1.设置为紧急状态 2 alter database 数据库名称 set emergency 3 --2.设置为单用户模式 4 alter database 数据库名称 set single_user 5 --3.检查并重建日志文件 6 dbcc checkdb('数据库名称',REPAIR_ALLOW_DATA_LOSS) 7 --4.第3步操作如果有错误提示,运行第4步,没有错误则跳过 8 dbcc checkdb('数据库名称',REPAIR_REBUILD) 9 --5.恢复成多用户模式10 alter database 数据库名称 set multi_user


6.至此会重新生成改库的日志文件,整个过程完成

  或者也可以采用手动附加(本方法参考@码道程工)


    相关评论

    阅读本文后您有什么感想? 已有人给出评价!

    • 8 喜欢喜欢
    • 3 顶
    • 1 难过难过
    • 5 囧
    • 3 围观围观
    • 2 无聊无聊

    热门评论

    最新评论

    发表评论 查看所有评论(0)

    昵称:
    表情: 高兴 可 汗 我不要 害羞 好 下下下 送花 屎 亲亲
    字数: 0/500 (您的评论需要经过审核才能显示)