Database Stuck in Single-User Mode Due to Botched Restore
Working in a development environment, I botched up a restore. After this restore attempt to overwrite my database with the previous version, I had it stuck in single-user mode.
SSMS provided me with helpful messages such as this:
Changes to the state or options of database 'PoorDb' cannot be made at this time. The database is in single-user mode, and a user is currently connected to it.
Additionally, I was told I was the deadlock victim when attempting to set the user mode back to multi-user.
Going forward I looked at several articles from Stack Overflow and various other blogs, and followed the recommended steps such as
I even added a step to kill the connections to it by using this statement, helpfully posted by Matthew Haugen
Finally went through and removed all my connections from master based on an additional post. No luck. Stopped my monitoring tools, no luck. At this point, it felt like a Monday for sure.
Since I was working in a development environment, I went all gung ho and killed every session with my login name, as there seemed to be quite a few , except for the spid executing. Apparently, the blocking process was executing from master, probably the incomplete restore that didn’t successfully rollback. I’ll have to improve my transaction handling on this, as I just ran it straight with no error checks.
What a waste of time, but at least I know to watch out next time, ensure my actions are checked for error and rolled back. I’m going to just blame it on the darn SSMS GUI. Seems like a convenient scapegoat this time.
Successful pushed out my changes with the following script: