Search code examples
c#.netentity-frameworkef-model-first

EF Model First: how to programmatically generate/delete database?


In the EF tutorials described the work with Model-First approach in the following way:

  1. create the model
  2. generate database sql from model
  3. launch generated sql via studio

But how it could be delivered to the customers? The database must be created on customers side automatically on program launch and it must be deleted when the customer select some menu action. How above behavior could be implemented via EF?


Solution

  • Your Model-First approach should have create a DbContext derived class, something like class MyModelContainer : DbContext.

    In the startup phase of your app, do something like this:

    using(var ctx = new MyModelContainer())
    {
       ctx.Database.CreateIfNotExists();
    }
    

    similarly, when you want to delete it (first close all connections):

    using(var ctx = new MyModelContainer())
    {
       ctx.Database.Delete();
    }