Header Ads

ASP.NET MVC5: Entity Framework Database First Approach

Entity Framework is a gateway between your application and your database. A simple reason why entity framework stands out is that it automatically generates object classes that maps with your database tables. In ASP.NET MVC5 platform entity framework also has the ability to generate complex types object mapping classes that correspond with your database store procedures using entity framework database first approach.

Today, I shall be demonstrating entity framework database first approach with ASP.NET MVC5 platform.

 
Prerequisites:

Following are some prerequisites before you proceed any further in this tutorial:
  1. Knowledge of ASP.NET MVC5.
  2. Knowledge of HTML.
  3. Knowledge of JavaScript.
  4. Knowledge of Bootstrap.
  5. Knowledge of Jquery.
  6. Knowledge of C# Programming.
The example code is being developed in Microsoft Visual Studio 2017 Professional. I have taken the data sample from AdventureWorks for SQL server 2014

Download Now!

Let's begin now.

1) Create a new MVC web project and name it "MVCDatabaseFirst".  

2) Although you can create your entity framework model inside any hierarchy of the project. But, I prefer "Models" folder, to keep code cleaner. So, right click on your "Models" folder and then click "Add->New Item" as shown below i.e.


3) Then choose "ADO.NET Entity Data Model", name it "DataAcessModel" and click "Add" as shown below i.e.


4) Now, from "Entity Data Model Wizard" choose "EF Designer from database", since I am creating entity framework database first approach model. Then click "Next" as shown below i.e.


5) On the "Choose Your Data Connection" window, click "New Connection" button as shown below i.e.


6) Then in "Connection Properties" window provide your SQL server connection configurations and then click "OK" as shown below i.e. your database connection string will be stored in "Web.config" file.


7) Now, on "Choose Your Data Connection" window, click "Yes, include sensitive data in connection string." option and click "Next" as shown below i.e.


8) Now, on "Choose Your Database Objects and Settings" window, choose your target database objects. In my case, I have select only the store procedures. Then click "Finish" as shown below i.e.


9) Ignore below shown security warning and click OK as shown below i.e.



You can see that your target mapping object classes and related methods have been created automatically by entity framework as shown below i.e.


10) To open your "Entity Data Model Browser" window, click "View->Other Windows->Entity Data Model Browser" as shown below i.e.

 

11) Now, create a new "Controllers\HomeController.cs" file and create GET Index(...) method and POST Index(...)  and update following lines of code in them i.e.


        ...

        public ActionResult Index(int productId = 0)
        {
            ...

                // Verification.
                if (model.ProductID > 0)
                {
                    // Settings.
                    var details = this.databaseManager.GetProductByID(model.ProductID);
                    model.ProductDetail = details.First();
                }

                // Settings.
                model.ProductsGreaterThan1000 = this.databaseManager.GetProductByPriceGreaterThan1000().ToList();

            ...
        }

        ...

        [HttpPost]
        [AllowAnonymous]
        [ValidateAntiForgeryToken]
        public ActionResult Index(ProductViewModel model)
        {
            ...

                // Verification
                if (ModelState.IsValid)
                {
                    // Info.
                    return this.RedirectToAction("Index", "Home", new { productId = model.ProductID });
                }

            ...
        }

In the above code, In GET Index(...) method, I am simply verifying if the product ID is greater than zero then get product ID base product details from the database. I am also displaying the list of products from the database into my web user interface. In the POST Index(...) method. I am simply redirecting the product ID value enter by the end-user to my GET Index(...) action method.

12) Now, execute the project and you will be able to see the following in action i.e.



Conclusion

In this article, you will learn to create the entity framework database first approach with ASP.NET MVC5 platform. You will learn to redirect your post requests to the GET action method. You will learn to configure your SQL server connection string in entity framework data model wizard. You will also learn to open your "Entity Data Model Browser" window and finally, you will learn to utilize your entity framework auto-genrated methods and object classes.