删除sqlserver数据库日志文件和附加没有日志文件的数据库解决办法
&删除数据库日志文件的方法
你曾经有在执行SQL的时候,数据库报事务日志已满,然后执行报错。然后纠结于怎么删除数据库日志,捣鼓半天吗,现在就提供两种删除日志文件的方法,希望能够帮到你!
方法一:手工操作
1.数据库->右键->属性->选项-恢复模式->由完成切换成简单
2.数据库->右键->任务->收缩-文件->由完成切换成简单->文件类型->日志->将文件收缩到
方法二:存储过程代替手工操作
--日志文件收缩至多少MDECLARE@DBLogSiseASINTSET@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.然后再执行 EXEC dbo.usp_p_delDBLog @DBLogSise = 0 (收缩至多少M)
回到顶部
示例存储过程下载
usp_p_delDBLog.sql
附加没有日志文件的数据库方法
今天客户那边执行SQL报错,经查看是客户服务器数据库磁盘已被全部用完,日志文件达到500GB的程度,后来由于我的错误操作导致日志文件(.ldf)被删除,后来附加.mdf文件老是说没有日志文件附加不成功,后来经过一番折腾终于解决了,下面分享一下!
操作步骤
1.新建同名的数据库文件
2.暂停SQLSetver服务
3.将原先的mdf文件,覆盖新建的数据库,删除新数据库的ldf文件
4.重新启动SQLSetver服务 ,这时看到的数据库是这个样子的,打不开
5.执行以下SQL语句
1--1.设置为紧急状态2alterdatabase数据库名称setemergency3--2.设置为单用户模式4alterdatabase数据库名称setsingle_user5--3.检查并重建日志文件6dbcccheckdb('数据库名称',REPAIR_ALLOW_DATA_LOSS)7--4.第3步操作如果有错误提示,运行第4步,没有错误则跳过8dbcccheckdb('数据库名称',REPAIR_REBUILD)9--5.恢复成多用户模式10alterdatabase数据库名称setmulti_user
6.至此会重新生成改库的日志文件,整个过程完成
或者也可以采用手动附加(本方法参考@码道程工)
相关阅读
- TFS2008SP1, 升级数据库从SQL2005SP3到SQL2008SP1
- 2000W条数据的Oralce数据库SQL查询优化经验
- zclesam创建SMD数据库的缘由
- 恢复丢失的SQLServer日志文件 避免导致数据库彻底毁坏
- SQL Server数据库优化的10多种方法
- 几种数据库类型说明及发展历史
- MySQL数据库怎么实现远程连接访问
- MS SQL Server 2008数据库怎么实现数据库同步备份?
- 10款免费的MySQL数据库图形化管理工具
- SQLite内存数据库
《删除sqlserver数据库日志文件和附加没有日志文件的数据库解决办法》由网友“不简单”推荐。
转载请注明:http://www.modouwifi.com/jiaocheng/05201224462021.html