--- uid: mvc/overview/getting-started/database-first-development/creating-the-web-application title: "EF Database First with ASP.NET MVC: Creating the Web Application and Data Models | Microsoft Docs" author: tfitzmac description: "Using MVC, Entity Framework, and ASP.NET Scaffolding, you can create a web application that provides an interface to an existing database. This tutorial seri..." ms.author: aspnetcontent manager: wpickett ms.date: 10/01/2014 ms.topic: article ms.assetid: bc8f2bd5-ff57-4dcd-8418-a5bd517d8953 ms.technology: dotnet-mvc ms.prod: .net-framework msc.legacyurl: /mvc/overview/getting-started/database-first-development/creating-the-web-application msc.type: authoredcontent --- EF Database First with ASP.NET MVC: Creating the Web Application and Data Models ==================== by [Tom FitzMacken](https://github.com/tfitzmac) > Using MVC, Entity Framework, and ASP.NET Scaffolding, you can create a web application that provides an interface to an existing database. This tutorial series shows you how to automatically generate code that enables users to display, edit, create, and delete data that resides in a database table. The generated code corresponds to the columns in the database table. > > This part of the series focuses on creating the web application, and generating the data models based on your database tables. ## Create a new ASP.NET Web Application In either a new solution or the same solution as the database project, create a new project in Visual Studio and select the **ASP.NET Web Application** template. Name the project **ContosoSite**. ![create project](creating-the-web-application/_static/image1.png) Click **OK**. In the New ASP.NET Project window, select the **MVC** template. You can clear the **Host in the cloud** option for now because you will deploy the application to the cloud later. Click **OK** to create the application. ![select mvc template](creating-the-web-application/_static/image2.png) The project is created with the default files and folders. In this tutorial, you will use Entity Framework 6. You can double-check the version of Entity Framework in your project through the Manage NuGet Packages window. If necessary, update your version of Entity Framework. ![show version](creating-the-web-application/_static/image3.png) ## Generate the models You will now create Entity Framework models from the database tables. These models are classes that you will use to work with the data. Each model mirrors a table in the database and contains properties that correspond to the columns in the table. Right-click the **Models** folder, and select **Add** and **New Item**. ![add new item](creating-the-web-application/_static/image4.png) In the Add New Item window, select **Data** in the left pane and **ADO.NET Entity Data Model** from the options in the center pane. Name the new model file **ContosoModel**. ![create model](creating-the-web-application/_static/image5.png) Click **Add**. In the Entity Data Model Wizard, select **EF Designer from database**. ![generate from database](creating-the-web-application/_static/image6.png) Click **Next**. If you have database connections defined within your development environment, you may see one of these connections pre-selected. However, you want to create a new connection to the database you created in the first part of this tutorial. Click the **New Connection** button. ![connect to database](creating-the-web-application/_static/image7.png) In the Connection Properties window, provide the name of the local server where your database was created (in this case **(localdb)\ProjectsV12**). After providing the server name, select the ContosoUniversityData from the available databases. ![set connection properties](creating-the-web-application/_static/image8.png) Click **OK**. The correct connection properties are now displayed. You can use the default name for connection in the Web.Config file ![connection settings](creating-the-web-application/_static/image9.png) Click **Next**. Select **Tables** to generate models for all three tables. ![select tables](creating-the-web-application/_static/image10.png) Click **Finish**. If you receive a security warning, select **OK** to continue running the template. The models are generated from the database tables, and a diagram is displayed that shows the properties and relationships between the tables. ![diagram of model](creating-the-web-application/_static/image11.png) The Models folder now includes many new files related to the models that were generated from the database. ![show new model files](creating-the-web-application/_static/image12.png) The **ContosoModel.Context.cs** file contains a class that derives from the **DbContext** class, and provides a property for each model class that corresponds to a database table. The **Course.cs**, **Enrollment.cs**, and **Student.cs** files contain the model classes that represent the databases tables. You will use both the context class and the model classes when working with scaffolding. Before proceeding with this tutorial, build the project. In the next section, you will generate code based on the data models, but that section will not work if the project has not been built. >[!div class="step-by-step"] [Previous](setting-up-database.md) [Next](generating-views.md)