- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在使用 ExecuteStoreQuery
时遇到以下异常 检索当前数据库日期:
The types in the assembly 'XYZ' cannot be loaded because the assembly contains
the EdmSchemaAttribute, and the closure of types is being loaded by name.
Loading by both name and attribute is not allowed.
at System.Data.Metadata.Edm.ObjectItemCollection.LoadAssemblyFromCache(
ObjectItemCollection objectItemCollection, Assembly assembly,
Boolean loadReferencedAssemblies, EdmItemCollection edmItemCollection,
Action`1 logLoadMessage)
at System.Data.Metadata.Edm.MetadataWorkspace.ImplicitLoadAssemblyForType(
Type type, Assembly callingAssembly)
at System.Data.Objects.ObjectContext.ExecuteStoreQueryInternal[TElement](
String commandText, String entitySetName, MergeOption mergeOption,
Object[] parameters)
at (my method)
有问题的方法包含
var timestamp = context.ExecuteStoreQuery<DateTime>("SELECT GetDate() ").First();
我之前使用过规范函数 CurrentDateTime
,但这也在调试配置中导致了此异常。 现在它只在发布配置中抛出。
我发现这个确切的异常只被提到过几次,主要是它与在一个程序集中混合代码优先和数据库优先方法有关,我相信我已经在我的案例中排除了这种情况。
生成的代码确实包含
[assembly: EdmSchemaAttribute()]
但我不知道是哪种类型导致了这种情况 - 我不知道也不知道如何找到它们。
如果我只使用 LINQ to Entities,它似乎一切正常。
目前,我依赖我们的服务器时间同步并且根本不查询数据库时间 - 不推荐这样做,但遗憾的是,这不是我们代码库中依赖它的第一件事。
以及问题:
代码生成器包含上述属性的原因可能是什么?我怎样才能防止这种情况发生?什么是合理的解决方法(导入包含 SELECT GetDate()
的存储过程似乎有点矫枉过正)?还有为什么这只发生在发布配置中?我没有找到有关基于编译器符号和选项的 EF 优化/差异的信息...
最佳答案
历史上(在 EF1 中)EF 只能使用从 EntityObject 类派生的实体并具有无数属性 - 例如每个实体都必须有 EdmEntityType 属性,每个属性都必须有 EdmProperty 属性等等。包含实体的程序集必须具有 EdmSchemaAttribute。加载类型时,EF 会查找 EdmSchemaAttribute,如果找到它,它就会知道此程序集包含需要加载的基于 EntityObject 的实体。在 EF4 中,添加了对 POCO 类型的支持。现在,您不再需要按照约定让任何属性和类型与您的模型相匹配。但是,限制是您不能混合使用 POCO 和非 POCO 类型(因此会出现异常)。 VS2008 SP1 和 VS2010 中的默认代码生成器生成基于 EntityObject 的实体和基于 ObjectContext 的上下文。存在非 POCO 实体,为了使 EF 能够找到它们,添加了 EdmSchemaAttribute。在 VS2012 中,默认生成 POCO 实体并且不生成 EdmSchemaAttribute(它实际上会阻止查找 POCO 实体)。最后,VS 代码库上有适用于 VS2010 的 T4 模板,您可以使用它从设计器生成 POCO 实体。您只需将模板添加到您的项目,并在设计器中将“代码生成策略”从“默认”更改为“无”。
关于c# - 元数据异常 : Schema specified is not valid when using ExecuteStoreQuery in Release configuration,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15783159/
我认为我的问题与“https://serverfault.com/q/299179”和“https://serverfault.com/q/283330/71790”有些相关,但其中任何一个都没有令我
我生成了 APK 对于我的 flutter 项目和 F:\build\app\outputs\apk\release 我有 3 种类型的 apk 文件,包括 output.json 文件。他们是: *
我们最近决定更新 Beta release 的新应用程序在 Google Play 上, 现在读完指南后,我心里有一些问题,想了解更多,我用谷歌搜索进一步了解找到了一些答案,但还有一些我不确定的东西,
我正在尝试使用发布管理作为构建版本的工具,但我很难理解码件、工具和操作之间的真正区别。有人可以分解这三个概念之间的差异以及它们如何相互配合吗? 最佳答案 由于它适用于基于代理的版本: 工具旨在提供自定
我最近完成了使用 jgitflow:release-finish 合并一个发布分支来掌握和开发。 .构建成功。 但是现在我正在尝试使用 jgitflow:releast-start 创建一个新分支.但
我一直在读到,如果一个集合“被释放”,它也会释放它的所有对象。另一方面,我还读到,一旦集合被释放,集合就会释放它的对象。 但最后一件事可能并不总是发生,正如苹果所说。系统决定是否取消分配。在大多数情况
我在具有以下布局的多模块项目上使用 maven-release-plugin: ROOT/ + parent + module1 + module2 在parent的pom中,使用modu
我正在使用 ionic 构建移动应用。 我面临一个严重的问题。 我必须使用 on-touch 和 on-release 事件,但问题是每当我触摸时,on-release 甚至也会立即触发而没有实际释放
谁能解释清楚两者之间的区别是什么.Release()和->Release() 在 CComPtr 上? 确切地说,两种情况下内存管理是如何发生的? 最佳答案 CComPtr 的operator-> 函
两个片段有什么区别? [myObj release]; 和 [myObj release]; myObj = nil; 最佳答案 如果你只是释放一个对象,那么它就会变成释放对象。 如果您尝试对已释放的
我正在运行 maven 发布插件 (org.apache.maven.plugins:maven-release-plugin:2.3.2) 并注意到当通过命令行。我想知道是否有办法关闭它。 我使用
我正在尝试通过运行nuget pack -properties Configuration=Release命令来更新我的nuget软件包,但这会给我以下错误: Unable to find 'bin/
我们正在使用 Microsoft 的发布管理将我们的 Web 应用程序部署到我们的测试环境 (QA)。它是一个直接的 MVC.Net Web 应用程序。我们的构建生成一个 web 部署包,我们有一个命
我有一个在 X 环境中发布的版本 A。另一方面,我有一个在环境 Y 中发布的版本 B。 问题是我想知道我是否可以在版本 B 中检查版本 A 的状态,这样我就可以抛出错误而不发布版本 B。 我不知道是否
我正在开发一个使用大量图像的应用程序,我正在使用 UIWebView 使用 JavaScript 代码(我正在使用 UIZE 库)来表示大约 200 张图像,问题当我完成 UIWebView 时,我在
我已阅读 Marshal.GetIUnknownForObject 的文档它说: Always use Marshal.Release to decrement the reference count
为了成为 iPhone SDK 上的好内存公民,我一直在玩内存。 然而,我仍然很难理解"self.something" 和只是"something" 之间的区别。 据我了解,"self.somethi
我需要使用 bash 找出我正在运行的 Linux 发行版。找到this page ,这非常有帮助。 但是我的系统有两个/etc/*-release 文件 /etc/lsb-release /etc/
我想使用 Maven Release Plugin 将 Release Candidates 发布到我的 Nexus Snapshot 存储库。 将 RC 部署到 Nexus 不是问题,但我想利用 m
在什么情况下我们应该使用“Latch until release”而不是“Switch until release”? 根据 LabVIEW 2011 Help : Latch until relea
我是一名优秀的程序员,十分优秀!