我有以下代码:
open FSharp.Data
[<Literal>]
let connectionString = @"Data Source=(local)\SQLExpress;Integrated Security=SSPI;Database=SfagStage"
type InsertEnhet = SqlCommandProvider<"Sql\InsertEnhet.sql", connectionString>
let insertEnhet (enhet:Enhet) =
let cmd = new InsertEnhet() // <<--- This generates an error runtime
cmd.Execute(enhet.Navn, enhet.Enhetsnummer, enhet.LEIKode, enhet.Kommune, DateTime.Now)
我认为我创建命令的行是导致缺少方法的原因。我认为重要的例外部分是:
System.MissingMethodException: Method not found: 'Void FSharp.Data.ISqlCommand Implementation..ctor(FSharp.Data.Connection, Int32, System.String, Boolean, System.Data.SqlClient.SqlParameter[], FSharp.Data.ResultType, FSharp.Data.ResultRank, Microsoft.FSharp.Core.FSharpFunc`2, System.String)'.
这是当你没有正确的方法时可能会遇到的异常bindingRedirect
for FSharp.Core.dll
。查看马克·西曼的这篇文章。原则上,我认为添加app.config
with bindingRedirect
您的应用程序应该可以解决问题。
当在使用新版本 FSharp.Core 的应用程序中使用针对旧版本 FSharp.Core 编译的库时,通常会发生这种情况。 .NET 运行时加载新版本的 FSharp.Core,但它不知道旧版本中的类型(例如FSharpFunc
) 应该映射到新版本中的相应类型 - 所以你会得到 MethodMissing,因为 .NET 认为FSharpFunc
是与加载的类型不同的类型。 (尽管类型提供者的事情变得有点复杂。)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)