- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我们正在开发一个大型的 ASP.NET Core MVC 1.0 应用程序。我们的每个应用程序都有 4 层,如下所示:
目前,在我们处理所有数据库操作的存储库中,我们已将数据库连接字符串硬编码在 DbContext 中,如下所示:
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) {
optionsBuilder.UseSqlServer("Data Source=somedatabase.database.windows.net;Initial Catalog=database;Integrated Security=False;User ID=username;Password=password;Connect Timeout=60;Encrypt=True;TrustServerCertificate=False;ApplicationIntent=ReadWrite;MultiSubnetFailover=False;MultipleActiveResultSets=true");
}
该项目作为独立的 ASP.NET Core 1.0 项目在 MVC 项目之外。它还有一个空的 Program.cs 文件,似乎需要执行代码到数据库的命令行(dotnet ef migrations add 和 dotnet ef database update)。
我们在 DbConext 中使用硬编码连接字符串的原因是,当我们使用以下代码时,在执行 dotnet ef 命令时,我们得到一个对象引用未设置为对象异常的实例。
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) {
optionsBuilder.UseSqlServer(ConfigurationManager.ConnectionStrings["StandardDatabase"].ConnectionString);
}
但是,由于我们有 Program.cs,如果我们为连接字符串添加 Debug.WriteLine 并运行项目,它会返回正确的连接字符串,如果我们在 appsettings.json 文件中设置连接字符串UI,UI 也将成功连接。
问题:上面提到的堆栈是我们用于几个“微应用程序”的堆栈,这意味着我们有几个连接到多个数据库的项目。我们还想利用 Development、Staging 和 Production 连接字符串。
如果我们使用 Configuration Manager Connection String,对于日常操作来说一切都很好;然而,当我们想要将 Entity Framework 代码用于数据库命令行时,我们需要进入我们想要更新的每个存储库并将 DbContext 更改为硬编码连接字符串,执行命令,然后在完成后将它们更改回,这就变得很麻烦了。
问题:我们是否做错了,是否有设置 Entity Framework Core 1.0 堆栈的首选做法,使我们不必手动更改 DbContext,而是全面利用配置文件?
任何方向将不胜感激!
最佳答案
EF Core 旨在通过依赖注入(inject)进行配置。依赖注入(inject)使您的 DbContext 保持干净,并且独立于环境的实现细节。
您最初的硬编码连接字符串解决方案将 DbContext 与数据库所在位置的知识紧密耦合。这显然是个问题。但是您提出的解决方案将 DbContext 与特定配置文件的知识紧密结合在一起。这也是一个问题。
要使 DbContext 独立于环境细节,请创建一个构造函数,该构造函数采用 DbContextOptions
参数并调用基类构造函数。
public class MyContext : DbContext
{
public MyContext(DbContextOptions options) :
base(options)
{
}
}
执行此操作而不是覆盖 OnConfiguring
。然后在宿主应用程序的 Startup.cs
中对其进行初始化。这就是配置文件的知识所在。
public class Startup
{
private IConfigurationRoot _configuration;
public Startup(IHostingEnvironment env)
{
_configuration = new ConfigurationBuilder()
.SetBasePath(env.ContentRootPath)
.AddJsonFile("appsettings.json")
.Build();
}
public void ConfigureServices(IServiceCollection services)
{
services.AddSingleton<IConfigurationRoot>(_configuration);
services.AddDbContext<MyContext>(options => options
.UseSqlServer(_configuration.GetConnectionString("MyContext")));
}
}
现在您可以从任何地方使用您的 DbContext。
关于c# - Entity Framework Core 1.0 连接字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38982387/
主要思想是将 EF Core nuget 包添加到 .NET Core 库项目,然后在一堆应用程序(例如 ASP.NET Core、Win 服务、控制台应用程序)中使用该库,而无需在每个应用程序中配置
我想要实现的是编写一个简单的.net核心后台工作程序(.net core 3.1)的代码,在该工作程序作为Windows服务运行时,我在其中将数据写入SQL Server数据库(通过EF Core 3
关于 .Net Core SDK download page 二进制文件有什么用?它与安装程序有何不同? 最佳答案 二进制文件是 .NET Core 的编译代码。它们拥有运行 .NET Core 所需
.NET Core 和 Entity Framework Core 之间的区别?我们可以在 .NET Core 中使用 Entity Framework Core 吗?两者都有什么优势? 最佳答案 E
.NET Core 和 ASP.NET Core 到底有什么区别? 它们是相互排斥的吗?我听说 ASP.NET Core 是基于 .NET Core 构建的,但它也可以基于完整的 .NET 框架构建。
我对 ASP.NET Core 开发完全陌生。我正在尝试使用单个模型和 mysql 创建一个简单的 asp.net core Web api 来存储模型数据,然后我想使用 Swagger 将其作为 R
.NET Core 和 Entity Framework Core 之间的区别?我们可以在 .NET Core 中使用 Entity Framework Core 吗?两者都有什么优势? 最佳答案 E
好吧,作为一个新的 .net 开发生态系统,我有点迷失在核心工具、版本等方面。 有人可以解释我之间的区别吗 VS 2015 核心工具预览版 x - See here .NET Core/SDK 与否
我已阅读有关如何通过信号器核心集线器从后台服务向客户端发送通知的文档。如何从客户端接收到后台服务的通知? 后台服务应该只是一个单例。 public class Startup { public
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 4年前关闭。 Improve t
非常简单的问题: 我正在尝试创建一个像这样的谓词构建器: var predicate = PredicateBuilder.False(); 但似乎在Net Core和EF Core中不可用。
在 .NET Core 自包含应用程序 中...我们需要在 project.json 中指定运行时 (RID) 我们希望我们的应用程序针对...发布为什么会这样? .NET Core 是跨平台的,与我
如何用 iCloud Core Data 替换我现有的 Core Data?这是我的持久商店协调员: lazy var persistentStoreCoordinator: NSPersistent
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 2 年前。 Improv
今天我正在学习新的 ASP.net 核心 API 3.1,我想将我的旧网站从 MVC4 转移到 Web API。除了一件事,一切都很好。数据库连接。在我的旧网站中,我为每个客户端(10/15 数据库)
我在 Visual Studio 2015 Update 3 和 .NET Core 1.0 中工作。我有一个 .NETCoreApp v1.0 类型的 Web API 项目。当我添加一个 .NET
我一直在尝试遵循 Ben Cull ( http://benjii.me/2016/06/entity-framework-core-migrations-for-class-library-proj
当我打开我的 vs 代码程序时,我收到以下消息: 无法找到 .NET Core SDK。 .NET Core 调试将不会启用。确保 .NET Core SDK 已安装并且在路径上。 如果我安装甚至卸载
我偶然发现了一个非常奇怪的问题。每当 Web 应用程序启动时,dotnet.exe 都会使用相当多的内存(大约 300M)。然而,当它触及某些部分时(我感觉这与 EF Core 使用有关),它会在短时
ASP.NET Core Web (.NET Core) 与 ASP.NET Core Web (.NET Framework) 有什么区别? .NET Framework 是否提供 similar
我是一名优秀的程序员,十分优秀!