使用Entity Framework,我创建了一个应用程序,该应用程序能够从其建模所依据的数据库中读取数据。我现在有另一个数据库,其中包含相同的表,托管在另一台服务器上。
问题是第二个数据库上的表所属的模式与原始数据库的名称不同,因此简单地更改app.config文件中我的上下文的连接字符串是不起作用的。(我得到错误“表或视图不存在”)。在自动生成的代码中,必须有某种映射来声明原始模式名称。
处理这种情况的正确方法是什么?我真的不想重新建模第二个数据库,因为它与第一个完全相同。我不能更改数据库,因为其他应用程序会停止工作。
任何在正确方向上的推动都将受到极大的赞赏。
发布于 2013-04-30 04:09:45
好的,下面是我为解决这个问题所做的工作。
正如@Kelmen在评论中提到的,在文本编辑器中打开EDMX文件会发现这是存储模式信息的位置。因此,我想我可以简单地清除schema属性的值,并使用连接字符串来驱动模式。
这感觉不太对劲,原因有几个:
解决方案是使用Code First和Fluent API在我派生的DbContext类中的OnModelCreating事件中编辑模型配置。
我现在正在考虑修改我的上下文类,这样我就可以传入模式的名称,或者可能从我的app.config中驱动它。
我发现这些链接教程非常有用:
https://stackoverflow.com/questions/16231412
复制相似问题