删除sqlserver数据库日志和没有日志的数据库恢复办法
2014-06-05 21:35
411 查看
一、删除数据库日志文件的方法
你曾经有在执行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.至此会重新生成改库的日志文件,整个过程完成
或者也可以采用手动附加(本方法参考@码道程工)
您可能感兴趣的文章:
相关文章推荐
- 删除sqlserver数据库日志和没有日志的数据库恢复办法
- SQL SERVER 数据日志太大,磁盘没有空间,直接删除数据库日志后,显示 恢复挂起。
- SQLserver2012-2014数据库 日志和没有日志的数据库恢复办法
- SQL2005 如何在没有日志文件的情况下如何恢复MDF数据库文件
- 日志文件满而不慎把数据库日志文件误删除时的恢复步骤
- MSSQLServer数据库附加没有日志文件解决办法
- SQL Server 2012日志文件误删除数据库质疑后的相关恢复
- 一次血的教训,阿里云rds mysql 数据库,本地化并日志恢复已删除的两天数据
- SQL2005 如何在没有日志文件的情况下如何恢复MDF数据库文件
- 只有mdf 没有 日志 恢复数据库
- 【Oracle】数据库运行状态下物理删除所有redo日志恢复方法
- 恢复已删除日志文件的数据库
- ORA-03113: end-of-file on communication channel ORA-00257: archiver error. Connect 归档日志满导致数据库没有办法启动
- Oracle数据库利用日志挖掘来恢复误删除的数据
- MS Sql Server无日志数据库恢复办法
- sql server 没有日志文件只有数据文件(.mdf) 的数据库恢复方法
- SQLServer2005 没有日志文件(*.ldf) 只有数据文件(*.mdf) 恢复数据库的方法
- SQL2005 如何在没有日志文件的情况下如何恢复MDF数据库文件?
- 【SQLServer】【恢复挂起的解决方案】附加文件时候的提示“无法重新生成日志,原因是数据库关闭时存在打开的事务/用户,该数据库没有检查点或者该数据库是只读的。 ”【数据库恢复】
- SQLServer2005 没有日志文件(*.ldf) 只有数据文件(*.mdf) 恢复数据库的方法