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

作者:junjie 时间:2024-01-21 23:20:55 

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

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

方法一:手工操作

1.数据库->右键->属性->选项-恢复模式->由完成切换成简单
2.数据库->右键->任务->收缩-文件->由完成切换成简单->文件类型->日志->将文件收缩到

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

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

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

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

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

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


--日志文件收缩至多少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服务 ,这时看到的数据库是这个样子的,打不开

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

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数据库日志和没有日志的数据库恢复办法

标签:sqlserver,数据库日志
0
投稿

猜你喜欢

  • python基础入门之普通操作与函数(三)

    2023-11-01 22:52:17
  • Python类如何定义私有变量

    2023-04-18 11:23:23
  • JS中实现JAVA的hashCode算法

    2008-08-03 17:00:00
  • python之yield表达式学习

    2022-05-06 14:51:43
  • 如何从SQL数据库中调用图片?

    2009-11-15 19:59:00
  • Python的几个高级语法概念浅析(lambda表达式闭包装饰器)

    2021-08-07 14:18:45
  • 7个perl数组高级操作技巧分享

    2022-08-09 10:38:19
  • CSS3:文字阴影知多少

    2009-06-28 15:33:00
  • 基于vue的video播放器的实现示例

    2024-05-05 09:23:31
  • Python中使用logging模块代替print(logging简明指南)

    2023-05-13 16:02:04
  • asp如何制作一个文本文件编辑器?

    2010-07-07 12:26:00
  • python的类class定义及其初始化方式

    2023-08-07 11:52:15
  • Vue父组件和子组件之间数据传递和方法调用

    2023-07-02 17:01:57
  • Python subprocess模块学习总结

    2022-04-29 02:17:40
  • 分享vim python缩进等一些配置

    2022-09-28 00:12:55
  • 基于php socket(fsockopen)的应用实例分析

    2023-11-18 21:38:32
  • Python提取PDF指定内容并生成新文件

    2022-11-09 19:44:00
  • 浅析vue给不同环境配置不同打包命令

    2024-04-30 08:45:59
  • HTML文件HEAD内部标签用法浅析

    2008-07-06 20:56:00
  • UCDChina.com 关于用户期望的讨论

    2008-07-10 11:55:00
  • asp之家 网络编程 m.aspxhome.com