我跟踪了很多这样的问题,我得到了一个简单的错误,但我不能解决这个问题。
我的Dapper版本是1.50.1我的Microsoft.SqlServer.Types版本是11.0.2
我在配置文件中添加了绑定重定向,如下所示:
<runtime>
<dependentAssembly>
<assemblyIdentity name="Microsoft.SqlServer.Types" publicKeyToken="89845dcd8080cc91" culture="neutral" />
<bindingRedirect oldVersion="10.0.0.0" newVersion="11.0.0.0" />
</dependentAssembly>
</runtime>我得到的错误是:
错误分析列2 (Location=POINT (-122.349 47.651) - Object)
而内部例外是:
不能将AMicrosoft.SqlServer.Types.SqlGeography转换为BMicrosoft.SqlServer.Types.SqlGeography。类型A来源于位于location 'C:\WINDOWS\assembly\GAC_MSIL\Microsoft.SqlServer.Types\10.0.0.0__89845dcd8080cc91\Microsoft.SqlServer.Types.dll'.的上下文中的“Microsoft.SqlServer.Types、Version=10.0.0.0、Culture=neutral、PublicKeyToken=89845dcd8080cc91”B类型源自位于location 'C:\WINDOWS\assembly\GAC_MSIL\Microsoft.SqlServer.Types\11.0.0.0__89845dcd8080cc91\Microsoft.SqlServer.Types.dll'.的上下文中的“Microsoft.SqlServer.Types、Version=11.0.0.0、Culture=neutral、PublicKeyToken=89845dcd8080cc91”
如果我只是读取一个动态对象,一切都好,但是如果我读到了我自己的有SqlGeography的类型,我就会得到这个错误。
我以为我做的都是推荐的,但似乎我错过了什么。
发布于 2017-01-04 18:12:06
尝试读取主题这篇文章上的SQL数据类型(几何、地理和层次结构)。
或者,尝试在connectionString中添加以下内容:
"Type System Version=SQL Server 2012",强制SqlClient加载程序集的11.0版本
发布于 2017-12-08 10:52:08
@Marc在这方面做得很好,参见下面的参考资料,这将拯救你的生命。
对于ASP.NET应用程序,将以下代码行添加到Global.asax.cs中的Application_Start方法:
SqlServerTypes.Utilities.LoadNativeAssemblies(Server.MapPath("~/bin"));对于桌面应用程序,在执行任何空间操作之前,添加以下代码行以运行:
SqlServerTypes.Utilities.LoadNativeAssemblies(AppDomain.CurrentDomain.BaseDirectory);.LoadNativeAssemblies方法将基于CPU体系结构为您获得正确的程序集。
在bin文件夹中,您应该拥有这个。

https://stackoverflow.com/questions/41459316
复制相似问题