ehxz 发表于 2006-12-18 23:01:10

如何修复SQLSERVER 数据库"置疑"问题

  你可以看到在SQLSERVER 的ERROR LOG 和OS的应用程序日志中应该有1105的错误信息:<br />  <br />  SQL Server事务日志可能会被填满,这会阻止之后的数据库操作,包括UPDATE, DELETE, INSERT 和CHECKPOINT。<br />  事务日志填满会导致1105错误:<br />  Can't allocate space for object syslogs in database dbname because<br />  the logsegment is full。 If you ran out of space in syslogs, dump<br />  the transaction log。 Otherwise use ALTER DATABASE or<br />  sp_extendsegment to increase the size of the segment。<br />  <br />  这种现象可能出现于任何一个数据库中,包括Master和TempDB。一些难以预见的因素可能消耗日志空间。 例如:<br />  一个大型事务, 尤其像批量数据更新、插入或删除。<br />  一个未提交的事务。<br />  检查点处理程序截除时所需的带宽过大。<br />  截除时超过阈值<br />  上述各种条件互相作用的结果。<br />  用于发布的标记事务没有被日志读取程序读走<br />  <br />  下面是修复的步骤和收缩日志的步骤:<br />  <br />  <b>1&#46;在命令提示符下运行以下命令启动 SQL Server:</b><br />  SQLSERVER -f -m<br />  <br />  备注:-m 开关以单用户模式启动 SQL Server。在单用户模式下,只能成功建立一个连接。 请注意是否有任何其他客户机或服务可能会在您通过 SQL Server 查询分析器  建立连接前使用那个连接。<br />  <br />  <b>2&#46; 重置置疑数据库的状态。</b><br />  sp_resetstatus 'database_name'<br />  <br />  下面是结果集:<br />  <br />  Database'database_name'status reset!<br />  WARNING: You must reboot SQL Server prior to accessing this database!<br />  <br />  <b>3&#46; 用 ALTER DATABASE 向数据库添加一个数据文件或日志文件:</b><br />  USE master<br />  GO<br />  CREATE DATABASE db_name ON<br />  (<br />  NAME = dbname_dat1,<br />  FILENAME = 'D:\MSSQL\Data\dbname_dat1&#46;ndf',<br />  SIZE = 1000MB,<br />  FILEGROWTH = 50MB<br />  )<br />  GO<br />  --更改该数据库以添加一个 2GB 大小的新数据文件<br />  ALTER DATABASE db_name<br />  ADD FILE<br />  (<br />  NAME = dbname_dat2,<br />  FILENAME = 'F:\MSSQL\DATA\dbname_dat2&#46;ndf',<br />  SIZE = 2000MB,<br />  FILEGROWTH = 50MB<br />  )<br />  GO<br />  --更改该数据库以添加一个1GB 大小的新日志文件<br />  ALTER DATABASE db_name<br />  ADD LOG FILE<br />  ( NAME = db_name_log2,<br />  FILENAME = 'F:\MSSQL\Data\db_name_log2&#46;ldf',<br />  SIZE = 1000MB,<br />  FILEGROWTH = 20MB),<br />  GO<br />  <br />  <b>4&#46; 停止并重新启动 SQL Server:</b><br />  用新的数据文件或日志文件所提供的额外空间,SQL Server 应该能完成数据库的恢复。<br />  <br />  <b>5&#46; 释放磁盘空间并且重新运行恢复操作,按照下面的步骤收缩日志。</b><br />  sp_resetstatus 关闭数据库的置疑标志,但是原封不动地保持数据库的其它选项。<br />  <br />  为从根本上解决这样的问题,你可以按下面的操作配置SQLSERVER 2000:<br />  a&#46;如果不需要恢复到指定的时间点,你可以将数据库的恢复模式配置为简单,这样<br />  UPDATE,DELETE,SELECT就不会记录日志,日志就不会增加的很大:<br />  <br />  USE MASTER<br />  <br />  GO<br />  ALTER DATABASE DB_NAME SET RECOVERY SIMPLE<br />  b&#46;如果你的恢复模式是全部,你一定要配置日志字段收缩:<br />  <br />  USE MASTER<br />  <br />  GO<br />  sp_dboption 'databasename','trunc&#46; log on chkpt&#46;',true<br />  sp_dboption 'databasename','autoshrink',true<br />  c&#46;通过每日备份将日志收缩:<br />  BACKUP DATABASE DATABASE_NAME TO BACKUP_DEVICES<br />  BACKUP LOG DATABASE_NAME TO LOG_DEVICES<br />  OR<br />  BACKUP LOG DATABASE_NAME with truncate_only<br />  <br />  **检查日志的容量:DBCC SQLPERF (LOGSPACE) 这时日志并没有收缩!<br />  <br />  d&#46;每天在备份数据库完成之后,重新启动MS SQLSERVER SERVICE&#46;<br />  USE DATABASE_NAME<br />  go<br />  DBCC SHRINKFILE(2,truncateonly)<br />  <br />  **检查日志的容量:DBCC SQLPERF (LOGSPACE) 这时日志已经收缩!<br />  <br />  e&#46;手动快速收缩日志:<br />  / *run below script,you will shrink you database log files<br />  immediately, in my experience,you need to run the script for 3 or<br />  4 minutes before stopping it manually */<br />  use databasename<br />  dbcc shrinkfile(2,notruncate)<br />  dbcc shrinkfile(2,truncateonly)<br />  create table t1(char1 char(4000))<br />  go<br />  declare @i int<br />  select @i=0<br />  while(1=1)<br />  begin<br />  while(@i<100)<br />  begin<br />  INSERT INTO T1 VALUES ('A')<br />  SELECT @I=@I+1<br />  END<br />  TRUNCATE table T1<br />  BACKUP LOG youdatabasename with truncate_only<br />  end<br />  GO<br />  <br />  注意 只有在您的主要支持提供者指导下或有疑难解答建议的做法时,才可以使用<br />  sp_resetstatus。否则,可能会损坏数据库。<br />  <br />  由于该过程修改了系统表,系统管理员必须在运行 sp_resetstatus这个过程前,启用系统表更新。要<br />  启 用更新,使用下面的过程:<br />  <br />  USE master<br />  GO<br />  sp_configure 'allow updates', 1<br />  GO<br />  RECONFIGURE WITH OVERRIDE<br />  GO<br />  过程创建后,立即禁用系统表更新:<br />  <br />  sp_configure 'allow updates', 0<br />  GO<br />  RECONFIGURE WITH OVERRIDE<br />  GO<br />  只有系统管理员才能执行 sp_resetstatus。执行该过程后,立即关闭 SQL Server<br /><strong></strong>
页: [1]
查看完整版本: 如何修复SQLSERVER 数据库&quot;置疑&quot;问题