AspNetCore.Docs/aspnetcore/tutorials/first-mvc-app-mac/adding-model.md

161 lines
6.5 KiB
Markdown
Raw Normal View History

---
title: Adding a model to an ASP.NET MVC Core app
author: rick-anderson
description: Add a model to a simple ASP.NET Core app.
keywords: ASP.NET Core, MVC, scaffold, scaffolding
ms.author: riande
manager: wpickett
ms.date: 03/30/2017
ms.topic: get-started-article
ms.assetid: 8dc28498-eeee-1638-b903-b593059e9f39
ms.technology: aspnet
ms.prod: asp.net-core
uid: tutorials/first-mvc-app-mac/adding-model
---
[!INCLUDE[adding-model](../../includes/mvc-intro/adding-model1.md)]
* In Solution Explorer, right-click the **MvcMovie** project, and then select **Add** > **New Folder**. Name the folder *Models*.
* Right-click the *Models* folder, and then select **Add** > **New File**.
* In the **New File** dialog:
* Select **General** in the left pane.
* Select **Empty Class** in the center pain.
* Name the class **Movie** and select **New**.
Add the following properties to the `Movie` class:
[!code-csharp[Main](../../tutorials/first-mvc-app/start-mvc/sample/MvcMovie/Models/MovieNoEF.cs?name=snippet_1)]
The `ID` field is required by the database for the primary key.
Build the project to verify you don't have any errors. You now have a **M**odel in your **M**VC app.
## Prepare the project for scaffolding
- Right click on the project file, and then select **Tools > Edit File**.
![view of above step](adding-model/_static/1.png)
- Add the following highlighted NuGet packages to the *MvcMovie.csproj* file:
[!code-csharp[Main](start-mvc/sample/MvcMovie.csproj?highlight=5,14-21)]
- Save the file.
- Create a *Models/MvcMovieContext.cs* file and add the following `MvcMovieContext` class:
[!code-csharp[Main](../../tutorials/first-mvc-app-xplat/start-mvc/sample/MvcMovie/Models/MvcMovieContext.cs)]
- Open the *Startup.cs* file and add two usings:
[!code-csharp[Main](../../tutorials/first-mvc-app-xplat/start-mvc/sample/MvcMovie/Startup.cs?name=snippet1&highlight=1,2)]
- Add the database context to the *Startup.cs* file:
[!code-csharp[Main](../../tutorials/first-mvc-app-xplat/start-mvc/sample/MvcMovie/Startup.cs?name=snippet2&highlight=6-7)]
This tells Entity Framework which model classes are included in the data model. You're defining one *entity set* of Movie objects, which will be represented in the database as a Movie table.
- Build the project to verify there are no errors.
## Scaffold the MovieController
Open a terminal window in the project folder and run the following commands:
```
dotnet restore
dotnet aspnet-codegenerator controller -name MoviesController -m Movie -dc MvcMovieContext --relativeFolderPath Controllers --useDefaultLayout --referenceScriptLibraries
```
If you get the error `No executable found matching command "dotnet-aspnet-codegenerator", verify`:
* You are in the project directory. The project directory has the *Program.cs*, *Startup.cs* and *.csproj* files.
* Your dotnet version is 1.1 or higher. Run `dotnet` to get the version.
* You have added the `<DotNetCliToolReference>` elment to the [MvcMovie.csproj file](#prepare-the-project-for-scaffolding).
<!--
> [!NOTE]
> If you get an error when the scaffolding command runs, see [issue 444 in the scaffolding repository](https://github.com/aspnet/scaffolding/issues/444) for a workaround.
-->
The scaffolding engine creates the following:
* A movies controller (*Controllers/MoviesController.cs*)
* Razor view files for Create, Delete, Details, Edit and Index pages (*Views/Movies/\*.cshtml*)
The automatic creation of [CRUD](https://en.wikipedia.org/wiki/Create,_read,_update_and_delete) (create, read, update, and delete) action methods and views is known as *scaffolding*. You'll soon have a fully functional web application that lets you manage a movie database.
### Add the files to Visual Studio
* Add the *MovieController.cs* file to the Visual Studio project:
* Right-click on the *Controllers* folder and select **Add > Add Files**.
* Select the *MovieController.cs* file.
* Add the *Movies* folder and views:
* Right-click on the *Views* folder and select **Add > Add Existing Folder**.
* Navigate to the *Views* folder, select *Views\Movies*, and then select **Open**.
* In the **Select files to add from Movies** dialog, select **Include All**, and then **OK**.
### Create the database
You'll call the `EnsureCreated` method to cause EF Core to create the database if it doesn't exist.
This is a method you typically use only in a development environment. It creates a database to match your data model when you run the app for the first time. When you change your data model, you drop the database. The next time the app runs, EF Core creates a new database to match your new data model.
This approach doesn't work well in production, because you have data you don't want to lose by dropping the database. EF Core includes a [Migrations](xref:data/ef-mvc/migrations) feature that lets you preserve data when you make data model changes, but you won't be using Migrations in this tutorial. You'll learn more about data model changes in the [Add a field](xref:tutorials/first-mvc-app-xplat/new-field) tutorial.
<!-- todo - update link above with mac version -->
Create a *Models\DBinitialize.cs* file and add the following code:
<!-- todo - replace this with code import -->
```c#
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.DependencyInjection;
using System;
namespace MvcMovie.Models
{
public static class DBinitialize
{
public static void EnsureCreated(IServiceProvider serviceProvider)
{
var context = new MvcMovieContext(
serviceProvider.GetRequiredService<DbContextOptions<MvcMovieContext>>());
context.Database.EnsureCreated();
}
}
}
```
Call the `EnsureCreated` method from the `Configure` method in the *Startup.cs* file. Add the call to the end of the method:
<!-- todo - replace this with code import -->
```c#
app.UseMvc(routes =>
{
routes.MapRoute(
name: "default",
template: "{controller=Home}/{action=Index}/{id?}");
});
DBinitialize.EnsureCreated(app.ApplicationServices);
}
```
[!INCLUDE[adding-model](../../includes/mvc-intro/adding-model3.md)]
You now have a database and pages to display, edit, update and delete data. In the next tutorial, we'll work with the database.
## Additional resources
* [Tag Helpers](xref:mvc/views/tag-helpers/intro)
* [Globalization and localization](xref:fundamentals/localization)
>[!div class="step-by-step"]
[Previous Adding a View](adding-view.md)
[Next Working with SQL](working-with-sql.md)