- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个带有 SQL 数据库的现有应用程序,该数据库已使用数据库优先模型进行编码(每次架构更改时我都会创建一个 EDMX 文件)。
一些额外的开发(支持原始应用程序的 Windows 服务)已经完成,它使用 EF POCO/DbContext 作为数据层而不是 EF EDMX 文件。 DbContext 中从未配置过初始化设置,但它们从未修改过数据库,因为 DbSet 对象始终与表匹配。
现在,我已经编写了一个单独的应用程序,它使用现有数据库,但只使用它自己的新表,它使用 EFs 初始化程序自行创建。我原以为现在是使用 EF Code First 来管理这些新表的好时机。我第一次运行该应用程序时一切正常,但现在我从我的一些原始 EF POCO DbContext(从未使用过初始化程序)中收到此错误。
The model backing the 'ServerContext' context has changed since the database was created. Consider using Code First Migrations to update the database
经过一些调查,我发现 EF 将其架构的哈希值与某个存储在 sql server 某处的哈希值进行比较。这个值在上下文实际使用数据库上的初始化程序之前不存在(在我的例子中,直到最近的应用程序添加它的表)。
现在,我的其他 DbContext 在读取现在存在的哈希值时抛出错误,但它与自己的哈希值不匹配。使用 EDMX 的 EF 连接没有任何错误。
似乎解决方案是将这一行放在遇到问题的所有 DbContext 中的 protected override void OnModelCreating(DbModelBuilder modelBuilder)
中
Database.SetInitializer<NameOfThisContext>(null);
但是,如果稍后我想编写另一个应用程序并让它首先使用 EF 代码再次创建自己的表,现在我将永远无法协调这个理论甚至更新的上下文与导致现在问题。
有没有办法清除 EF 存储在数据库中的哈希值? EF 是否足够智能以仅更改在当前上下文中作为 DbSet 存在的表?任何见解表示赞赏。
最佳答案
是的,有界数据库上下文实际上是一种很好的做法。例如,一个基础上下文类,使用到数据库的公共(public)连接,每个子类,使用数据库.SetInitializer(null);按照你的建议。
然后继续并拥有 1 个具有“数据库 View ”的大型上下文,该上下文负责所有迁移,并且只有该上下文应该执行此操作。单一事实来源。
让多个上下文负责数据库迁移是一场噩梦,我认为您无法解决。弄乱由代码优先迁移创建的系统条目只能以泪流满面。
我在 A julie Lerman 视频中看到的正是您描述的主题。她建议的解决方案是单个“迁移”上下文,然后使用多个有界数据库上下文。
如果您有 pluralsight 帐户: http://pluralsight.com/training/players/PsodPlayer?author=julie-lerman&name=efarchitecture-m2-boundedcontext&mode=live&clip=11&course=efarchitecture
关于c# - 一个数据库具有多个上下文的 EF Initializer,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14328272/
我正在尝试将 keras.initializers 引入我的网络,following this link : import keras from keras.optimizers import RMS
我正在为程序创建某种前端。为了启动程序,我使用了调用 CreateProcess(),其中接收到一个指向 STARTUPINFO 结构的指针。初始化我曾经做过的结构: STARTUPINFO star
我已经模板化了 gray_code 类,该类旨在存储一些无符号整数,其基础位以格雷码顺序存储。这里是: template struct gray_code { static_assert(st
我已经查看了之前所有与此标题类似的问题,但我找不到解决方案。所有错误都表明我没有初始化 ArrayList。我是否没有像 = new ArrayList 这样初始化 ArrayList? ? impo
当涉及到 Swift 类时,我对必需的初始化器和委托(delegate)的初始化器有点混淆。 正如您在下面的示例代码中所见,NewDog 可以通过两种方式中的一种进行初始化。如您所见,您可以通过在初始
几天来我一直在为一段代码苦苦挣扎。我在运行代码时收到的错误消息是: 错误:数组初始值设定项必须是初始值设定项列表 accountStore(int size = 0):accts(大小){} 这里似乎
我想返回一个数组,因为它是否被覆盖并不重要,我的方法是这样的: double * kryds(double linje_1[], double linje_2[]){ double x = linje
尝试在 C++ 中创建一个简单的 vector 时,出现以下错误: Non-aggregates cannot be initialized with initializer list. 我使用的代码
如何在构造函数中(在堆栈上)存储初始化列表所需的临时状态? 例如,实现这个构造函数…… // configabstraction.h #include class ConfigAbstraction
我正在尝试编写一个 native Node 插件,它枚举 Windows 机器上的所有窗口并将它们的标题数组返回给 JS userland。 但是我被这个错误难住了: C:\Program Files
#include using namespace std; struct TDate { int day, month, year; void Readfromkb() {
我很难弄清楚这段代码为何有效。我不应该收到“数组初始值设定项必须是初始值设定项列表”错误吗? #include class B { public: B() { std::cout << "B C
std::map m = { {"Marc G.", 123}, {"Zulija N.", 456}, {"John D.", 369} }; 在 Xcode 中,我将 C+
为了帮助你明白这一点,我给出了我的代码:(main.cpp),只涉及一个文件。 #include #include using namespace std; class test{ public
这在 VS2018 中有效,但在 2008 中无效,我不确定如何修复它。 #include #include int main() { std::map myMap = {
我有一个类: #include class Object { std::shared_ptr object_ptr; public: Object() {} template
我正在为 POD、STL 和复合类型(如数组)开发小型(漂亮)打印机。在这样做的同时,我也在摆弄初始化列表并遇到以下声明 std::vector arr{ { 10, 11, 12 }, { 20,
我正在使用解析实现模型。 这是我的代码。 import Foundation import UIKit import Parse class User { var objectId : String
我正在观看 Java 内存模型视频演示,作者说与 Lazy Initialization 相比,使用 Static Lazy Initialization 更好,我不清楚他说的是什么想说。 我想接触社
如果您查看 Backbone.js 的源代码,您会看到此模式的多种用途: this.initialize.apply(this, arguments); 例如,这里: var Router =
我是一名优秀的程序员,十分优秀!