PRB: Missing Device Causes Database to Be Marked SuspectLast reviewed: February 23, 1998Article ID: Q180500 |
The information in this article applies to:
SYMPTOMSSQL Server marks a database suspect if any of the device files for the database are unavailable when it attempts to start. You may see either of the following sets of messages in the SQL Server error log:
96/11/18 10:48:32.60 kernel udopen: Operating System Error 32 (The process cannot access the file because it is being used by another process.) during the creation/opening of physical device, C:\DATA\SQL\MSDB.DAT 96/11/18 10:48:32.60 kernel udactivate (primary): failed to open device C:\MSSQL\DATA\MSDB.DAT for vdn 127 -or- 96/11/18 10:48:32.60 kernel udopen: operating system error 2(The system cannot find the file specified.) during the creation/opening of physical device C:\MSSQL\DATA\MSDB.DAT 96/11/18 10:48:32.60 kernel udactivate (primary): failed to open device C:\MSSQL\DATA\MSDB.DAT for vdn 127These will be followed later in the log by:
96/11/18 10:48:36.70 kernel udread: Operating system error 6(The handle is invalid.) on device 'C:\MSSQL\DATA\MSDB.DAT' (virtpage 0x7f000018). 96/11/18 10:48:36.77 spid11 Error : 840, Severity: 17, State: 2 96/11/18 10:48:36.77 spid11 Device 'MSDBData' (with physical name 'C:\MSSQL\DATA\MSDB.DAT', and virtual device number 127) is not available. Please contact System Administrator for assistance. 96/11/18 10:48:36.77 spid11 Buffer 1092480 from database 'msdb' has page number 0 in the page header and page number 24 in the buffer header 96/11/18 10:48:37.43 spid11 Unable to proceed with the recovery of dbid <5> because of previous errors. Continuing with the next database.For example, performing the following steps will demonstrate the problem:
select name, dbid, mode, status from sysdatabases where dbid = select db_id('msdb')You receive the following results:
name dbid mode status ------------------------------ msdb 5 0 328The status of 328 evaluates to:
truncate log on chkpt database not recovered yet database is suspectFor more information, see the "Sysdatabases (Master Database Only)" topic in the SQL Server Books Online.
CAUSEAt startup, SQL Server attempts to obtain an exclusive lock on the device file. If the device is being used by another process (for example, backup software) or if the file is missing, the scenario described above will be encountered. In these cases, there is usually nothing wrong with the devices and database. For the database to recover correctly, the device must be made available, and the database status must be reset.
WORKAROUNDTo work around this problem, perform the steps below. Note that the final step is critical.
MORE INFORMATIONIf the database is still marked as suspect after performing these steps, there may be other problems preventing the database from recovering. At this point, you can either restore from a good backup or set the database to emergency mode and use the bulk copy program (BCP) to bulk copy the data out. For more information, see the following article in the Microsoft Knowledge Base:
ARTICLE-ID: Q165918 TITLE : INF: Bypass (Emergency) Mode and DUMP TRANSACTION WITH NO_LOGIMPORTANT: If you use this article (Q165918) and are unsure of the full consequences of any of the actions you are performing, contact your primary support provider for assistance.
|
Additional query words: db checkpoint
© 1998 Microsoft Corporation. All rights reserved. Terms of Use. |