网站首页  汉语字词  英语词汇  考试资料  写作素材  旧版资料

请输入您要查询的范文:

 

标题 删除sqlserver数据库日志和没有日志的数据库恢复办法
范文
    这篇文章主要介绍了删除sqlserver数据库日志和没有日志的数据库恢复办法,需要的朋友可以参考下。
    一、删除数据库日志文件的方法
    你曾经有在执行SQL的时候,数据库报事务日志已满,然后执行报错。然后纠结于怎么删除数据库日志,捣鼓半天吗,现在就提供两种删除日志文件的方法,希望能够帮到你!
    方法一:手工操作
    1.数据库->右键->属性->选项-恢复模式->由完成切换成简单
    2.数据库->右键->任务->收缩-文件->由完成切换成简单->文件类型->日志->将文件收缩到
    
    
    
    
    方法二:存储过程代替手工操作
    代码如下:
    --日志文件收缩至多少M
    DECLARE@DBLogSiseASINT
    SET@DBLogSise=0
    --查询出数据库对应的日志文件名称
    DECLARE@strDBNameASNVARCHAR(500)DECLARE@strLogNameASNVARCHAR(500)DECLARE@strSQLASVARCHAR(1000)
    SELECT
    @strLogName=B.name,@strDBName=A.nameFROMmaster.sys.databasesASAINNERJOINsys.master_filesASBONA.database_id=B.database_idWHEREA.database_id=DB_ID()
    SET@strSQL='
    --设置数据库恢复模式为简单
    ALTERDATABASE['+@strDBName+']SETRECOVERYSIMPLE;
    --收缩日志文件
    DBCCSHRINKFILE('''+@strLogName+''','+CONVERT(VARCHAR(20),@DBLogSise)+');
    --恢复数据库还原模式为完整
    ALTERDATABASE['+@strDBName+']SETRECOVERYFULL'
    exec(@strSQL)
    1.在数据库中执行上面的存储过程
    2.然后再执行EXECdbo.usp_p_delDBLog@DBLogSise=0(收缩至多少M)
    二、没有日志文件的数据库恢复方法
    今天客户那边执行SQL报错,经查看是客户服务器数据库磁盘已被全部用完,日志文件达到500GB的程度,后来由于我的错误操作导致日志文件(.ldf)被删除,后来附加.mdf文件老是说没有日志文件附加不成功,后来经过一番折腾终于解决了,下面分享一下!
    操作步骤
    1.新建同名的数据库文件
    2.暂停SQLSetver服务
    3.将原先的mdf文件,覆盖新建的数据库,删除新数据库的ldf文件
    4.重新启动SQLSetver服务,这时看到的数据库是这个样子的,打不开
    
    5.执行以下SQL语句
    代码如下:
    --1.设置为紧急状态
    alterdatabase数据库名称setemergency
    --2.设置为单用户模式
    alterdatabase数据库名称setsingle_user
    --3.检查并重建日志文件
    dbcccheckdb('数据库名称',REPAIR_ALLOW_DATA_LOSS)
    --4.第3步操作如果有错误提示,运行第4步,没有错误则跳过
    dbcccheckdb('数据库名称',REPAIR_REBUILD)
    --5.恢复成多用户模式
    alterdatabase数据库名称setmulti_user
    6.至此会重新生成改库的日志文件,整个过程完成或者也可以采用手动附加
    
随便看

 

在线学习网范文大全提供好词好句、学习总结、工作总结、演讲稿等写作素材及范文模板,是学习及工作的有利工具。

 

Copyright © 2002-2024 cuapp.net All Rights Reserved
更新时间:2025/5/23 20:48:10