热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何修复SQLSERVER数据库"置_sqlserver

     如果SQLServer因为磁盘可用空间不足,而不能完成数据库的恢复,那么 SQLServer2000会返回错误1105并且将sysdatabases中的s

      如果 SQL Server 因为磁盘可用空间不足,而不能完成数据库的恢复,那么  SQL Server 2000 会返回错误 1105 并且将 sysdatabases 中的 status 列设为置疑。

你可以看到在sqlserver 的ERROR LOG 和OS的应用程序日志中应该有1105的错误信息:

SQL Server事务日志可能会被填满,这会阻止之后的数据库操作,包括UPDATE, DELETE, INSERT 和CHECKPOINT。

http://www.gaodaima.com/35381.html如何修复SQLSERVER 数据库"置_sqlserver

事务日志填满会导致1105错误:
    Can’t allocate space for object syslogs in database dbname because
    the logsegment is full。 If you ran out of space in syslogs, dump
    the transaction log。 Otherwise use ALTER DATABASE or
    sp_extendsegment to increase the size of the segment。

这种现象可能出现于任何一个数据库中,包括Master和TempDB。一些难以预见的因素可能消耗日志空间。 例如:
一个大型事务, 尤其像批量数据更新、插入或删除。
一个未提交的事务。
检查点处理程序截除时所需的带宽过大。
截除时超过阈值
上述各种条件互相作用的结果。
用于发布的标记事务没有被日志读取程序读走

下面是修复的步骤和收缩日志的步骤:

   1.在命令提示符下运行以下命令启动 SQL Server:

            SQLSERVER -f -m

       备注:-m 开关以单用户模式启动 SQL Server。在单用户模式下,只能成功建立一个连接。 请注意是否有任何其他客户机或服务可能会在您通过 SQL Server 查询分析器    建立连接前使用那个连接。

   2. 重置置疑数据库的状态。

        sp_resetstatus ‘database_name’

下面是结果集:

Database’database_name’status reset!WARNING: You must reboot SQL Server prior to accessing this database!

  3. 用 ALTER DATABASE 向数据库添加一个数据文件或日志文件:

USE masterGOCREATE DATABASE db_name ON( NAME = dbname_dat1, FILENAME = ‘D:/MSSQL/Data/dbname_dat1.ndf’, SIZE = 1000MB, FILEGROWTH = 50MB)GO

–更改该数据库以添加一个 2GB 大小的新数据文件ALTER DATABASE db_nameADD FILE ( NAME = dbname_dat2, FILENAME = ‘F:/MSSQL/DATA/dbname_dat2.ndf’, SIZE = 2000MB, FILEGROWTH = 50MB)GO–更改该数据库以添加一个1GB 大小的新日志文件ALTER DATABASE db_nameADD LOG FILE ( NAME = db_name_log2, FILENAME = ‘F:/MSSQL/Data/db_name_log2.ldf’, SIZE = 1000MB, FILEGROWTH = 20MB),GO

    4. 停止并重新启动 SQL Server:
   用新的数据文件或日志文件所提供的额外空间,SQL Server 应该能完成数据库的恢复。

     5. 释放磁盘空间并且重新运行恢复操作,按照下面的步骤收缩日志。
 sp_resetstatus 关闭数据库的置疑标志,但是原封不动地保持数据库的其它选项。

为从根本上解决这样的问题,你可以按下面的操作配置SQLSERVER 2000:
a.如果不需要恢复到指定的时间点,你可以将数据库的恢复模式配置为简单,这样
UPDATE,DELETE,SELECT就不会记录日志,日志就不会增加的很大:

     USE MASTER

    GO
     ALTER DATABASE DB_NAME SET RECOVERY SIMPLE
b.如果你的恢复模式是全部,你一定要配置日志字段收缩:

    USE MASTER

    GO
    sp_dboption ‘databasename’,’trunc. log on chkpt.’,true
    sp_dboption ‘databasename’,’autoshrink’,true
c.通过每日备份将日志收缩:
   BACKUP DATABASE DATABASE_NAME TO BACKUP_DEVICES
   BACKUP LOG DATABASE_NAME TO LOG_DEVICES
   OR
   BACKUP LOG DATABASE_NAME with truncate_only

   **检查日志的容量:DBCC SQLPERF (LOGSPACE) 这时日志并没有收缩!

d.每天在备份数据库完成之后,重新启动MS SQLSERVER SERVICE.
     USE DATABASE_NAME
     go
     DBCC  SHRINKFILE(2,truncateonly)

  **检查日志的容量:DBCC SQLPERF (LOGSPACE) 这时日志已经收缩!

e.手动快速收缩日志:
  / *run  below  script,you  will  shrink  you  database  log  files
immediately,  in  my  experience,you  need  to  run  the  script  for  3  or
4  minutes  before stopping  it  manually  */
use  databasename
dbcc  shrinkfile(2,notruncate)
dbcc  shrinkfile(2,truncateonly)
create  table  t1(char1  char(4000))
go
declare  @i  int
select  @i=0
while(1=1)
begin
     while(@i<100)
             begin
           INSERT  INTO  T1  VALUES  (‘A’)
           SELECT  @[email protected]+1
           END
TRUNCATE  table  T1
BACKUP  LOG  youdatabasename  with  truncate_only
end
GO

 注意  只有在您的主要支持提供者指导下或有疑难解答建议的做法时,才可以使用
 sp_resetstatus。否则,可能会损坏数据库。

 由于该过程修改了系统表,系统管理员必须在运行 sp_resetstatus这个过程前,启用系统表更新。要
启 用更新,使用下面的过程:

 USE master
 GO
 sp_configure ‘allow updates’, 1
 GO
 RECONFIGURE WITH OVERRIDE
 GO
 过程创建后,立即禁用系统表更新:

 sp_configure ‘allow updates’, 0
 GO
 RECONFIGURE WITH OVERRIDE
 GO
 只有系统管理员才能执行 sp_resetstatus。执行该过程后,立即关闭 SQL Server。

 

请参考:

http://support.microsoft.com/default.aspx?scid=kb;zh-cn;317375

http://support.microsoft.com/default.aspx?scid=kb;zh-cn;307775

 

欢迎大家阅读《如何修复SQLSERVER 数据库"置_sqlserver》,跪求各位点评,若觉得好的话请收藏本文,by



推荐阅读
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文讨论了在使用sp_msforeachdb执行动态SQL命令时,当发生错误时如何捕获数据库名称。提供了两种解决方案,并介绍了如何正确使用'?'来显示数据库名称。 ... [详细]
  • Android系统源码分析Zygote和SystemServer启动过程详解
    本文详细解析了Android系统源码中Zygote和SystemServer的启动过程。首先介绍了系统framework层启动的内容,帮助理解四大组件的启动和管理过程。接着介绍了AMS、PMS等系统服务的作用和调用方式。然后详细分析了Zygote的启动过程,解释了Zygote在Android启动过程中的决定作用。最后通过时序图展示了整个过程。 ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
  • 在Oracle11g以前版本中的的DataGuard物理备用数据库,可以以只读的方式打开数据库,但此时MediaRecovery利用日志进行数据同步的过 ... [详细]
  • 解决Sharepoint 2013运行状况分析出现的“一个或多个服务器未响应”问题的方法
    本文介绍了解决Sharepoint 2013运行状况分析中出现的“一个或多个服务器未响应”问题的方法。对于有高要求的客户来说,系统检测问题的存在是不可接受的。文章详细描述了解决该问题的步骤,包括删除服务器、处理分布式缓存留下的记录以及使用代码等方法。同时还提供了相关关键词和错误提示信息,以帮助读者更好地理解和解决该问题。 ... [详细]
  • 微软评估和规划(MAP)的工具包介绍及应用实验手册
    本文介绍了微软评估和规划(MAP)的工具包,该工具包是一个无代理工具,旨在简化和精简通过网络范围内的自动发现和评估IT基础设施在多个方案规划进程。工具包支持库存和使用用于SQL Server和Windows Server迁移评估,以及评估服务器的信息最广泛使用微软的技术。此外,工具包还提供了服务器虚拟化方案,以帮助识别未被充分利用的资源和硬件需要成功巩固服务器使用微软的Hyper - V技术规格。 ... [详细]
  • 本文讨论了在数据库打开和关闭状态下,重新命名或移动数据文件和日志文件的情况。针对性能和维护原因,需要将数据库文件移动到不同的磁盘上或重新分配到新的磁盘上的情况,以及在操作系统级别移动或重命名数据文件但未在数据库层进行重命名导致报错的情况。通过三个方面进行讨论。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • 本文介绍了将mysql从5.6.15升级到5.7.15的详细步骤,包括关闭访问、备份旧库、备份权限、配置文件备份、关闭旧数据库、安装二进制、替换配置文件以及启动新数据库等操作。 ... [详细]
  • 基于Axis、XFire、CXF的webservice客户端调用示例
    本文介绍了如何使用Axis、XFire、CXF等工具来实现webservice客户端的调用,以及提供了使用Java代码进行调用的示例。示例代码中设置了服务接口类、地址,并调用了sayHello方法。 ... [详细]
  • 如何查询zone下的表的信息
    本文介绍了如何通过TcaplusDB知识库查询zone下的表的信息。包括请求地址、GET请求参数说明、返回参数说明等内容。通过curl方法发起请求,并提供了请求示例。 ... [详细]
author-avatar
家宇珮禎忠全
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有