微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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,并且应该解决您的问题.

希望这可以帮助

亚历克斯

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐