如何在控制器中获取数据库上下文
How to get the database context in a controller
我整天都在努力弄清楚如何在默认 MVC 6 项目的 ManageController.cs
中获取 ApplicationDbContext
。
我上网并用谷歌搜索了很多,但似乎没有人遇到与我相同的问题。这可能很简单,但我无法弄清楚。
有人有想法吗?
这是我尝试过的:
IServiceProvider service = new IServiceProvider();
var _context = service.GetService<ApplicationDbContext>();
使用构造函数注入:
public class ManageController
{
private readonly ApplicationDbContext _context;
public ManageController(ApplicationDbContext context)
{
_context = context;
}
}
然后您可以在控制器方法中使用 _context
对象。文档的 Dependency Injection 部分提供了更多信息。
我正在使用 Visual Studio 2015 Update 3。在 Visual Studio 的未来版本中可能不需要以下某些步骤。
使用 No Authentification
创建 ASP.NET 核心(使用 .NET 核心)项目。
在程序包管理器控制台中,依次执行以下各项。
Install-Package Microsoft.EntityFrameworkCore.SqlServer
Install-Package Microsoft.EntityFrameworkCore.Tools –Pre
Install-Package Microsoft.VisualStudio.Web.CodeGeneration.Tools -Pre
Install-Package Microsoft.VisualStudio.Web.CodeGenerators.Mvc -Pre
- 将以下内容添加到
project.json
中定义的 "tools":{}
。
"Microsoft.EntityFrameworkCore.Tools": "1.0.0-preview2-final",
"Microsoft.VisualStudio.Web.CodeGeneration.Tools": "1.0.0-preview2-final",
- 将以下内容添加到
appsettings.json
。
"ConnectionStrings": {
"DefaultConnection": "Server=(localdb)\mssqllocaldb;Database=YourDatabaseName;Trusted_Connection=True;MultipleActiveResultSets=true"
},
- 将以下内容添加到
startup.cs
中的 ConfigureServices
,就在 services.AddMvc();
之前。
string connection = Configuration.GetConnectionString("DefaultConnection");
services.AddDbContext<YourContextName>(options => options.UseSqlServer(connection));
我整天都在努力弄清楚如何在默认 MVC 6 项目的 ManageController.cs
中获取 ApplicationDbContext
。
我上网并用谷歌搜索了很多,但似乎没有人遇到与我相同的问题。这可能很简单,但我无法弄清楚。 有人有想法吗?
这是我尝试过的:
IServiceProvider service = new IServiceProvider();
var _context = service.GetService<ApplicationDbContext>();
使用构造函数注入:
public class ManageController
{
private readonly ApplicationDbContext _context;
public ManageController(ApplicationDbContext context)
{
_context = context;
}
}
然后您可以在控制器方法中使用 _context
对象。文档的 Dependency Injection 部分提供了更多信息。
我正在使用 Visual Studio 2015 Update 3。在 Visual Studio 的未来版本中可能不需要以下某些步骤。
使用
No Authentification
创建 ASP.NET 核心(使用 .NET 核心)项目。在程序包管理器控制台中,依次执行以下各项。
Install-Package Microsoft.EntityFrameworkCore.SqlServer
Install-Package Microsoft.EntityFrameworkCore.Tools –Pre
Install-Package Microsoft.VisualStudio.Web.CodeGeneration.Tools -Pre
Install-Package Microsoft.VisualStudio.Web.CodeGenerators.Mvc -Pre
- 将以下内容添加到
project.json
中定义的"tools":{}
。
"Microsoft.EntityFrameworkCore.Tools": "1.0.0-preview2-final",
"Microsoft.VisualStudio.Web.CodeGeneration.Tools": "1.0.0-preview2-final",
- 将以下内容添加到
appsettings.json
。
"ConnectionStrings": {
"DefaultConnection": "Server=(localdb)\mssqllocaldb;Database=YourDatabaseName;Trusted_Connection=True;MultipleActiveResultSets=true"
},
- 将以下内容添加到
startup.cs
中的ConfigureServices
,就在services.AddMvc();
之前。
string connection = Configuration.GetConnectionString("DefaultConnection");
services.AddDbContext<YourContextName>(options => options.UseSqlServer(connection));