Wanted to be proactive and move a database that was in the default path on
C:\ to a secondary drive as it was growing pretty heavily.
What I didn't realize was the adventure that would ensure.
Don't move a SQL Server database to a volume that someone has set NTFS Compression on at the drive level.
Copy the database next time, instead of moving. Would have eased my anxious dba mind since I didn't have a backup. before you judge me.. it was a dev oriented enviroment, not production… disclaimer finished
The Nasty Errors and Warnings Ensue
First, you'll get an error message if you try to mount the database and it has been compressed. Since I'd never done this before I didn't realize the mess I was getting into. It will tell you that you can't mount the database without marking as read-only as it's a compressed file.
Ok… so just go to
file explorer > properties > advanced > uncheck compress … right?
Changing File Attributes 'E:\DATA\FancyTacos.mdf' The requested operation could not be completed due to a file system limitation`
I found that message about as helpful as the favorite .NET error message
object reference not found that is of course so easy to immediately fix.
- Pull up volume properties. Uncheck compress drive OR
- If you really want this compression, then make sure to uncompress the folders containing SQL Server files and apply.
Since I wasn't able to fix this large of a file by toggling the file (it was 100gb+), I figured to keep it simple and try copying the database back to the original drive, unmark the archive attribute, then copy back to the drive I had removed compression on and see if this worked. While it sounded like a typical “IT Crowd” fix (have you tried turning it on and off again) I figured I'd give it a shot.
… It worked. Amazingly enough it just worked.
Here's a helpful script to get you on your way in case it takes a while. Use at your own risk, and please… always have backups! #DontBlameMeIfYouDidntBackThingsUp #CowsayChangedMyLife
and finally to remount the database after copying it back to your drive …