AspNetCore.Docs/aspnetcore/data/entity-framework-6.md

94 lines
5.8 KiB
Markdown
Raw Normal View History

---
2016-11-17 08:24:57 +08:00
title: Getting Started with ASP.NET Core and Entity Framework 6 | Microsoft Docs
author: tdykstra
description: This article shows how to use Entity Framework 6 in an ASP.NET Core application.
keywords: ASP.NET Core, Entity Framework, EF 6
ms.author: tdykstra
2016-10-29 01:35:15 +08:00
manager: wpickett
2017-04-12 06:20:49 +08:00
ms.date: 02/24/2017
2016-10-29 01:35:15 +08:00
ms.topic: article
ms.assetid: 016cc836-4c43-45a4-b9a7-9efaf53350df
2016-11-17 08:24:57 +08:00
ms.technology: aspnet
ms.prod: asp.net-core
2016-10-29 01:35:15 +08:00
uid: data/entity-framework-6
---
# Getting started with ASP.NET Core and Entity Framework 6
2016-10-29 01:35:15 +08:00
By [Paweł Grudzień](https://github.com/pgrudzien12), [Damien Pontifex](https://github.com/DamienPontifex), and [Tom Dykstra](https://github.com/tdykstra)
This article shows how to use Entity Framework 6 in an ASP.NET Core application.
2016-10-29 01:35:15 +08:00
## Overview
To use Entity Framework 6, your project has to compile against the full .NET Framework, as Entity Framework 6 does not support .NET Core. If you need cross-platform features you will need to upgrade to [Entity Framework Core](https://docs.efproject.net).
The recommended way to use Entity Framework 6 in an ASP.NET Core application is to put the EF6 context and model classes in a class library project that targets the full framework. Add a reference to the class library from the ASP.NET Core project. See the sample [Visual Studio solution with EF6 and ASP.NET Core projects](https://github.com/aspnet/Docs/tree/master/aspnetcore/data/entity-framework-6/sample/).
2016-10-29 01:35:15 +08:00
You can't put an EF6 context in an ASP.NET Core project because .NET Core projects don't support all of the functionality that EF6 commands such as *Enable-Migrations* require.
2016-10-29 01:35:15 +08:00
Regardless of project type in which you locate your EF6 context, only EF6 command-line tools work with an EF6 context. For example, `Scaffold-DbContext` is only available in Entity Framework Core. If you need to do reverse engineering of a database into an EF6 model, see [Code First to an Existing Database](https://msdn.microsoft.com/en-us/jj200620).
## Reference full framework and EF6 in the ASP.NET Core project
Your ASP.NET Core project needs to reference the full .NET framework and EF6. For example, the *.csproj* file of your ASP.NET Core project will look similar to the following example (only relevant parts of the file are shown).
[!code-xml[](entity-framework-6/sample/MVCCore/MVCCore.csproj?range=3-9&highlight=2)]
2016-10-29 01:35:15 +08:00
If youre creating a new project, use the **ASP.NET Core Web Application (.NET Framework)** template.
## Handle connection strings
The EF6 command-line tools that you'll use in the EF6 class library project require a default constructor so they can instantiate the context. But you'll probably want to specify the connection string to use in the ASP.NET Core project, in which case your context constructor must have a parameter that lets you pass in the connection string. Here's an example.
[!code-csharp[](entity-framework-6/sample/EF6/SchoolContext.cs?name=snippet_Constructor)]
2016-10-29 01:35:15 +08:00
Since your EF6 context doesn't have a parameterless constructor, your EF6 project has to provide an implementation of [IDbContextFactory](https://msdn.microsoft.com/library/hh506876). The EF6 command-line tools will find and use that implementation so they can instantiate the context. Here's an example.
[!code-csharp[](entity-framework-6/sample/EF6/SchoolContextFactory.cs?name=snippet_IDbContextFactory)]
2016-10-29 01:35:15 +08:00
In this sample code, the `IDbContextFactory` implementation passes in a hard-coded connection string. This is the connection string that the command-line tools will use. You'll want to implement a strategy to ensure that the class library uses the same connection string that the calling application uses. For example, you could get the value from an environment variable in both projects.
## Set up dependency injection in the ASP.NET Core project
In the Core project's *Startup.cs* file, set up the EF6 context for dependency injection (DI) in `ConfigureServices`. EF context objects should be scoped for a per-request lifetime.
[!code-csharp[](entity-framework-6/sample/MVCCore/Startup.cs?name=snippet_ConfigureServices&highlight=5)]
2016-10-29 01:35:15 +08:00
You can then get an instance of the context in your controllers by using DI. The code is similar to what you'd write for an EF Core context:
[!code-csharp[](entity-framework-6/sample/MVCCore/Controllers/StudentsController.cs?name=snippet_ContextInController)]
2016-10-29 01:35:15 +08:00
## Sample application
For a working sample application, see the [sample Visual Studio solution](https://github.com/aspnet/Docs/tree/master/aspnetcore/data/entity-framework-6/sample/) that accompanies this article.
2016-10-29 01:35:15 +08:00
This sample can be created from scratch by the following steps in Visual Studio:
* Create a solution.
* **Add New Project > Web > ASP.NET Core Web Application (.NET Framework)**
* **Add New Project > Windows Classic Desktop > Class Library (.NET Framework)**
2016-10-29 01:35:15 +08:00
* In **Package Manager Console** (PMC) for both projects, run the command `Install-Package Entityframework`.
* In the class library project, create data model classes and a context class, and an implementation of `IDbContextFactory`.
* In PMC for the class library project, run the commands `Enable-Migrations` and `Add-Migration Initial`. If you have set the ASP.NET Core project as the startup project, add `-StartupProjectName EF6` to these commands.
* In the Core project, add a project reference to the class library project.
* In the Core project, in *Startup.cs*, register the context for DI.
* In the Core project, in *appsettings.json*, add the connection string.
2016-10-29 01:35:15 +08:00
* In the Core project, add a controller and view(s) to verify that you can read and write data. (Note that ASP.NET Core MVC scaffolding won't work with the EF6 context referenced from the class library.)
## Summary
This article has provided basic guidance for using Entity Framework 6 in an ASP.NET Core application.
## Additional Resources
* [Entity Framework - Code-Based Configuration](https://msdn.microsoft.com/en-us/data/jj680699.aspx)