Restore the database (because the database is in use, it cannot obtain exclusive access to the database)

Source: Internet
Author: User

When restoring a database backup, the following error occurs: Because the database is in use, you cannot obtain exclusive access to the database.

Solution: modify some database names and execute the SQLCodeAnd then restore it immediately.

Use Master

Declare @ Dbname Varchar ( 20 )
Set @ Dbname = ' Dfd_test ' -- -This is the database name.

Declare @ SQL Nvarchar ( 500 )
Declare @ Spid Int -- The spid value is a unique integer assigned to the connection when the user connects.
Set @ SQL = ' Declare getspid cursor
Select spid from sysprocesses where dbid = db_id ( ''' + @ Dbname + ''' ) '
Exec ( @ SQL )
Open Getspid
Fetch Next From Getspid Into @ Spid
While @ Fetch_status <>- 1 -- If the fetch statement does not fail to be executed or this row is not in the result set.
Begin
Exec ( ' Kill ' + @ Spid ) -- Terminate normal connection
Fetch Next From Getspid Into @ Spid
End
Close Getspid
Deallocate Getspid

 

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.