data:image/s3,"s3://crabby-images/2f1fc/2f1fc64f0eacd60ae46040f26f70a10afc96a04b" alt=""
As you can see in the above screen capture, the T-SQL query gave the warning message upon execution:
You must recover this database prior to access
The next step was to set the SUSPECT database into an EMERGENCY mode. This was done by executing the below SQL query against the master database.
ALTER DATABASE test_dr SET EMERGENCY
Once the database is set to EMERGENCY mode it becomes a READ_ONLY copy and only members of sysadmin fixed server roles have privileges to access it. The basic purpose for this is to facilitate troubleshooting. I did not want other users updating the database while it was being worked on.data:image/s3,"s3://crabby-images/4e72e/4e72eb6379c4723a82ed64525187ec04ef33b53f" alt=""
As you can see from the above screen capture, once the T-SQL query got executed successfully the state of the database changed from SUSPECT to EMERGENCY.
Once the database state was changed to EMERGENCY. I then performrf a consistency check by executing the below T-SQL query against the master database.
DBCC checkdb('test_dr')
Which resulted in the below output:data:image/s3,"s3://crabby-images/13266/13266317ba04fbf88942bc58275588f96a20328b" alt=""
As seen from the above screen capture there is no issue with respect to consistency of the test_dr database. Also, this confirmed that the logical and physical integrity of the database was intact.
The next step was to set the database to SINGLE USER mode with ROLLBACK IMMEDIATE. To do this the below SQL query was executed against the master database.
ALTER DATABASE
test_dr SET SINGLE_USER
WITH ROLLBACK IMMEDIATE8
The above query will rollback any transactions if any are present in the test_dr database and will bring the database named test_dr into Single User mode.Please refer to the screen capture below:
data:image/s3,"s3://crabby-images/5487f/5487f26ad01665c3620fabd1b1972f10cb14ecce" alt=""
The next step was to perform a DBCC Checkdb along with Repair with Data Loss by executing the below T-SQL query against the master database.
DBCC CheckDB ('test_dr', REPAIR_ALLOW_DATA_LOSS)
This query will attempt to repair all reported errors. These repairs can cause some data loss.Once the DBCC CheckDB with the Repair with Data Loss option were executed, the Database went into Single User mode as shown below:
data:image/s3,"s3://crabby-images/d27c9/d27c94225caaab71d9fe13f6b8e3cda80807ad9f" alt=""
After performing the above step the database was brought ONLINE and Multiple Users access was enabled by executing the below T-SQL query against the master database.
ALTER DATABASE test_dr SET MULTI_USER
Please refer the screen capture below.data:image/s3,"s3://crabby-images/5f0a1/5f0a183e864c9d8a050b8779d6b5c6f1540b1261" alt=""
As you can see from the above screen capture the database named test_dr is back ONLINE. I am even able to view its objects as shown below:
data:image/s3,"s3://crabby-images/b6684/b668478091e1df106bdb0d559e73801623659aaa" alt=""
As final step for safety, I again checked the consistency of the database which was just repaired and brought ONLINE (i.e. the test_dr database) by executing the below T-SQL query against the master database.
DBCC CheckDB ('test_dr')
data:image/s3,"s3://crabby-images/09bb0/09bb003da6d639247df682880c8b0bcbfce40351" alt=""
After performing the above steps I ensured that all the required logins had access to the database with proper privileges. The application started working fine and the business was back on track. It took just 38 minutes to bring the SUSPECT database back ONLINE.
Please let me know if you have any comments on this approach or alternative approaches you have used in the past.
THE ULTIMATE SQL SERVER PERFORMANCE TOOL http://www.sqlsentry.com/download-trial/trial?utm_source=ssp&utm_medium=email&utm_content=3-feature-bullets-free-trial&utm_campaign=201505-complete-performance-solution&ad=201505-email-ssp-complete
Reference: http://www.sql-server-performance.com/2015/recovery-sql-server-suspect-mode/