一、删除数据库日志文件
日志较大删除,数据库报事务日志已满,然后执行报错。
两种删除的方法:
(一). 手工删除方法
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.在数据库中执行上面的存储过程
二、无日志文件的数据库恢复方法
错误操作导致日志文件(.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至此会重新生成改库的日志文件,整个过程完成