asp.net – 如何在使用edmx文件时在连接字符串中指定元数据位置

我有一个web项目,其中包含在edmx文件中定义的数据模型.连接字符串的开头如下:

元数据= RES:// * /;

这已经好了一段时间了.但是在项目上工作的其他人创建了一个dll,它也使用实体框架并将其添加到bin文件夹中.现在,当我尝试创建连接时,加载元数据时出错.

除了彻底改变我们中的一方或双方的工作方式之外,我想知道如果我的连接字符串可以更改为只查找我的edmx文件中定义的元数据,问题是否可以解决.问题是,对于我的生活,我找不到正确的语法来做到这一点.元数据嵌入在输出程序集中,因此没有指向的物理元数据文件.我究竟应该如何在连接字符串中指定元数据位置?

解决方法

是的我以前见过这个问题.有人问这个问题只是时间问题.

基本上res:// * /加载所有程序集中的所有元数据,因此如果有多组元数据,EF会混淆.

因此,认情况下使用res:// * /作为EF在WebApplications中执行是一个错误,不幸的是,它是我们没有时间解决的问题.

解决方法是使用类似这样的连接字符串更具体:
RES:///App_Code.northwind.csdl |高分辨率:///App_Code.northwind.ssdl |资源://*/App_Code.northwind.msl;

其中App_Code是App_Code文件夹(假设您的模型位于Web项目中),northwind是您的EDMX的名称.如果您无法获取要使用的名称,请使用Reflector之类的内容查看程序集中的资源名称.

这样做可以确切地告诉EF从加载的程序集中加载哪个CSDL,SSDL和MSL,并且应该解决您的问题.

希望这可以帮助

亚历克斯

相关文章

一、 PD简介PowerDesigner 是一个集所有现代建模技术于一身的...
一、存储过程 存储过程就像数据库中运行的方法(函数) 优点:...
一、Ueditor的下载 1、百度编辑器下载地址:http://ueditor....
推荐一款比较牛的富文本编辑器:http://kindeditor.net/
一、异或运算异或,英文为exclusive OR,或缩写成xor异或(x...
一、云计算概念 云计算(cloud computing)是基于互联网的相...