怎样修复SQLSERVER数据库置疑问题

上传人:luobi****88888 文档编号:92925503 上传时间:2019-07-14 格式:DOC 页数:8 大小:17KB
返回 下载 相关 举报
怎样修复SQLSERVER数据库置疑问题_第1页
第1页 / 共8页
怎样修复SQLSERVER数据库置疑问题_第2页
第2页 / 共8页
怎样修复SQLSERVER数据库置疑问题_第3页
第3页 / 共8页
怎样修复SQLSERVER数据库置疑问题_第4页
第4页 / 共8页
怎样修复SQLSERVER数据库置疑问题_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《怎样修复SQLSERVER数据库置疑问题》由会员分享,可在线阅读,更多相关《怎样修复SQLSERVER数据库置疑问题(8页珍藏版)》请在金锄头文库上搜索。

1、你可以看到在SQLSERVER 的ERROR LOG 和OS的应用程序日志中应该有1105的错误信息:SQL Server事务日志可能会被填满,这会阻止之后的数据库操作,包括UPDATE, DELETE, INSERT 和CHECKPOINT。事务日志填满会导致1105错误:Cant allocate space for object syslogs in database dbname becausethe logsegment is full。 If you ran out of space in syslogs, dumpthe transaction log。 Otherwise us

2、e ALTER DATABASE orsp_extendsegment to increase the size of the segment。这种现象可能出现于任何一个数据库中,包括Master和TempDB。一些难以预见的因素可能消耗日志空间。 例如:一个大型事务, 尤其像批量数据更新、插入或删除。一个未提交的事务。检查点处理程序截除时所需的带宽过大。截除时超过阈值上述各种条件互相作用的结果。用于发布的标记事务没有被日志读取程序读走下面是修复的步骤和收缩日志的步骤:1.在命令提示符下运行以下命令启动 SQL Server:SQLSERVER -f -m备注:-m 开关以单用户模式启动 SQ

3、L Server。在单用户模式下,只能成功建立一个连接。 请注意是否有任何其他客户机或服务可能会在您通过 SQL Server 查询分析器建立连接前使用那个连接。2. 重置置疑数据库的状态。sp_resetstatus database_name下面是结果集:Databasedatabase_namestatus reset!WARNING: You must reboot SQL Server prior to accessing this database!3. 用 ALTER DATABASE 向数据库添加一个数据文件或日志文件:USE masterGOCREATE DATABASE d

4、b_name ON(NAME = dbname_dat1,FILENAME = D:MSSQLDatadbname_dat1.ndf,SIZE = 1000MB,FILEGROWTH = 50MB)GO-更改该数据库以添加一个 2GB 大小的新数据文件ALTER DATABASE db_nameADD FILE(NAME = dbname_dat2,FILENAME = F:MSSQLDATAdbname_dat2.ndf,SIZE = 2000MB,FILEGROWTH = 50MB)GO-更改该数据库以添加一个1GB 大小的新日志文件ALTER DATABASE db_nameADD LO

5、G FILE( NAME = db_name_log2,FILENAME = F:MSSQLDatadb_name_log2.ldf,SIZE = 1000MB,FILEGROWTH = 20MB),GO4. 停止并重新启动 SQL Server:用新的数据文件或日志文件所提供的额外空间,SQL Server 应该能完成数据库的恢复。5. 释放磁盘空间并且重新运行恢复操作,按照下面的步骤收缩日志。sp_resetstatus 关闭数据库的置疑标志,但是原封不动地保持数据库的其它选项。为从根本上解决这样的问题,你可以按下面的操作配置SQLSERVER 2000:a.如果不需要恢复到指定的时间点,

6、你可以将数据库的恢复模式配置为简单,这样UPDATE,DELETE,SELECT就不会记录日志,日志就不会增加的很大:USE MASTERGOALTER DATABASE DB_NAME SET RECOVERY SIMPLEb.如果你的恢复模式是全部,你一定要配置日志字段收缩:USE MASTERGOsp_dboption databasename,trunc. log on chkpt.,truesp_dboption databasename,autoshrink,truec.通过每日备份将日志收缩:BACKUP DATABASE DATABASE_NAME TO BACKUP_DEVI

7、CESBACKUP LOG DATABASE_NAME TO LOG_DEVICESORBACKUP LOG DATABASE_NAME with truncate_only*检查日志的容量:DBCC SQLPERF (LOGSPACE) 这时日志并没有收缩!d.每天在备份数据库完成之后,重新启动MS SQLSERVER SERVICE.USE DATABASE_NAMEgoDBCCSHRINKFILE(2,truncateonly)*检查日志的容量:DBCC SQLPERF (LOGSPACE) 这时日志已经收缩!e.手动快速收缩日志:/ *runbelowscript,youwillshr

8、inkyoudatabaselogfilesimmediately,inmyexperience,youneedtorunthescriptfor3or4minutesbefore stoppingitmanually*/usedatabasenamedbccshrinkfile(2,notruncate)dbccshrinkfile(2,truncateonly)createtablet1(char1char(4000)godeclareiintselecti=0while(1=1)beginwhile(i100)beginINSERTINTOT1VALUES(A)SELECTI=I+1EN

9、DTRUNCATEtableT1BACKUPLOGyoudatabasenamewithtruncate_onlyendGO注意只有在您?闹饕痔峁咧傅枷禄蛴幸赡呀獯鸾榈淖龇保趴梢允褂?sp_resetstatus。否则,可能会损坏数据库。由于该过程修改了系统表,系统管理员必须在运行 sp_resetstatus这个过程前,启用系统表更新。要启 用更新,使用下面的过程:USE masterGOsp_configure allow updates, 1GORECONFIGURE WITH OVERRIDEGO过程创建后,立即禁用系统表更新:sp_configure allow updates, 0GORECONFIGURE WITH OVERRIDEGO只有系统管理员才能执行 sp_resetstatus。执行该过程后,立即关闭 SQL Server

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > IT计算机/网络 > 数据库

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号