I am struggling to keep up with DB changes and how to cleanly maintain and deploy DB changes from Dev to PRD from one release to another.
Currently, I use a SQL script to figure out what has changed since the last release;
- Procs and Views are the easier to take forward as i can simple drop and recreate if exist.
- Table Changes are more difficult since existing tables cannot be simply dropped.
But i think my main issue which i am unable to get my head around is that we have multiple mini releases to Dev and UAT between any two major PRD releases.
Dev and UAT mini releases are OK so far as I get a list of changes from other developers and I combined it with mine and then do a release and plus I am sys admin on the Dev and UAT DBs so I know exactly what is there and what happens when I apply the change.
For PRD I have to prepare a clean script and hand it over to the DBA so he can run it on there but apart from table names, columns and data on PRD I cannot view anything else.
and this script for PRD should capture almost everything that has gone into mini releases but most of the time these mini releases are not sequential and sometimes do negate each other as in one adds Feature A and then a subsequent release removes Feature A but for PRD we may have to add Feature A so no need to take second mini release which will effectively remove Feature A.
So in short I am looking at ways to manage and track DB changes between Releases and also a good way of building a deployment script for DB changes.
Note: I do keep a copy of all SQL objects in TFS maintained manually.
I tried using Database Project but I didnt get much luck achieving what I wanted.
Any ideas guys? any help much appreciated
I know am late but try redgate tool which is the best to control the source and synchronization of database objects. I have been using this tool for a long and convinced of the results. there are many options to sync your SQL scripts, users, security, settings & specially data from one to another database.