Database Projects and Source Control (TFS) JUST DO IT Database Projects and Source Control (TFS)
Leslie Weed Data/BI Architect – RevGen Partners DataVault Certified 20+ years IT
Have you heard this? My code disappeared My SSMS crashed and I lost all my work My fix didn’t get pushed out or deployed I don’t know what the code was that worked yesterday (and now it is broken) I wish I knew who originally worked on this I don’t know if that commented out code should or should not be in there Someone overwrote my fixes
Solution Technology AND Process
Database Projects (DAC Projects) Manage changes Apply version control Standardization between environments Script differences quickly and easily
Version Control (TFS) Versioning Multi-developer environment AND solo developer environment Review History Track changes No disappearing code Risk mitigation for the business (not about what the developer perceives as overhead)
Database Projects New project Existing project Layout Settings
Now TFS Adding to Source Control Or getting an existing project Settings Changes/Checkin History
Tips & Tricks Naming conventions Versions Renaming objects (you could lose data!) Get latest at the solution level – always DML – set build property to “NONE” Always add objects in solution explorer – NOT in source control explorer Refactor
Solution Explorer NOT Source Control Explorer
Make sure this is checked!! Tools>Options>SourceControl>Visual Studio Team Foundation Server
What your team needs Setting up the process with your team Get the latest before checking in (daily at a minimum) Confirm Database is error free prior to checkin Designate a deployment lead Everyone has their own schema compare file Pay attention – don’t get click happy
Your next steps Database Project - References, SQLCommand Mode Source Control – Branching and Merging https://blogs.msdn.microsoft.com/ssdt/2012/02/02/including-data-in-a-sql-server-database-project/ https://www.mssqltips.com/sqlservertutorial/9004/insert-inital-seed-data-into-the-table-in-ssdt/ http://sqlblog.com/blogs/jamie_thomson/archive/2014/10/13/day-10-code-navigation-30-days-of-ssdt.aspx www.sqlchick.com/entries/2016/1/10/why-you-should-use-a-ssdt-database-project-for-your-data-warehouse https://msdn.microsoft.com/en-us/library/hh272686(v=VS.103).aspx REFACTORING - https://msdn.microsoft.com/en-us/library/hh272704(v=vs.103).aspx
Creating a db project: In Visual Studio, Create a new database project, file>new>project then templates>sql server>sql server database project Update the name, location, solution name as desired. You may or may not want to add to source control at this time, if you do select the box Importing an existing db to your newly created project: In Visual Studio go to Solution Explorer window. Right click on the database (project level, not solution level) and your first option in the menu is import
Thank You Sponsors Platinum Gold Silver Bronze Swag Venue
Contact Leslie Weed lweed@revgen.com Twitter = @weederbug