当前位置: 移动技术网 > IT编程>数据库>MSSQL > 删除sqlserver数据库日志和没有日志的数据库恢复办法

删除sqlserver数据库日志和没有日志的数据库恢复办法

2017年12月12日  | 移动技术网IT编程  | 我要评论

男装服饰,你我是兄弟,延津县人民政府网

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

你曾经有在执行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)

二、没有日志文件的数据库恢复方法

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

操作步骤

1.新建同名的数据库文件
2.暂停sqlsetver服务
3.将原先的mdf文件,覆盖新建的数据库,删除新数据库的ldf文件
4.重新启动sqlsetver服务 ,这时看到的数据库是这个样子的,打不开


5.执行以下sql语句
复制代码 代码如下:

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

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

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


如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网