How to force drop database in SQL Server 2008

  • I'm trying to force drop a database, but after dropping the database, when I try to recreate the database, I'm getting the error

    cannot create file C:\Program Files.....[databasename].mdf because it already exists

    Here's my query to force drop the database

    Use master;
    ALTER database [databasename] set offline with ROLLBACK IMMEDIATE;
    DROP database [databasename];
    

    I understood that, the above query is dropping the database, but it's not deleting the .ldf and .mdf files. How to drop the database thoroughly?

    A normal query

    Drop database [databasename] ; //deletes the database completely, including the ldf and mdf's.
    

    How to force drop a database, which also deletes the .mdf and .ldf files?

  • marc_s

    marc_s Correct answer

    8 years ago

    That is expected and documented behavior:

    Dropping a database deletes the database from an instance of SQL Server and deletes the physical disk files used by the database. If the database or any one of its files is offline when it is dropped, the disk files are not deleted. These files can be deleted manually by using Windows Explorer. To remove a database from the current server without deleting the files from the file system, use sp_detach_db.

    So why are you taking your database offline first? Just set it into SINGLE_USER mode and then drop it as documented on SQL Server Books Online.-

    USE master;
    ALTER DATABASE [databasename] SET SINGLE_USER WITH ROLLBACK IMMEDIATE;
    DROP DATABASE [databasename] ;
    

    Note, database backups will not be deleted as part of the process documented above.

License under CC-BY-SA with attribution


Content dated before 6/26/2020 9:53 AM