C# Code-First migration, up/down?

C#Entity FrameworkCode FirstEntity Framework-Migrations

C# Problem Overview


Started to use the add-migration command in the package manager console to generate the migrations for my model. My question is, the up and down method. I assume that the purpose of the down method is to remove all dependencies and drop the tables if they are already in the database? Also that the down method will be executed before the up method? The up method is then the reverse, create/update tables/indexes etc?

Sometimes when i use this then the down method gets a lot of create tables that then are dropped? Recently it created and dropped a lot of tables and almost the same thing happened in the up method. Why?

C# Solutions


Solution 1 - C#

The Up method upgrades your database from its current state (represented by your previous migration) to the state expected by your current code migration. The Down method does the reverse operation - it removes all the changes from the current migration and reverts database to the state expected by the previous migration. It's like installing / uninstalling the migration. Only one of these methods is executed when you call update-database. To use the Down method you must explicitly specify the target migration for your upgrade. If the target migration is the old one, the migration API will automatically use the Down method and downgrade your database.

Solution 2 - C#

Just to add to @Ladislav Mrnka. I needed to use Down() for the first time and took me some time to make it work, so:

Update-Database -Target:201407242157114_46

Where my last migration is 47 (where new stuff was added). Here's a nice explanation of how to rollback the database and remove a bad migration.

Hope it might help other magician apprentices :)

Solution 3 - C#

Here, Up method will upgrade your database from its current state to the new state expected by you. The Down method will do the reverse. It will revert your database to the state expected from the previous migration

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionPatrickView Question on Stackoverflow
Solution 1 - C#Ladislav MrnkaView Answer on Stackoverflow
Solution 2 - C#HerGizView Answer on Stackoverflow
Solution 3 - C#Abdus Salam AzadView Answer on Stackoverflow