EF连接Sqlserver2014,使用DBGeography时提示无法加载sqlserverspatial.dll

Posted GIS的天空

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了EF连接Sqlserver2014,使用DBGeography时提示无法加载sqlserverspatial.dll相关的知识,希望对你有一定的参考价值。

(1)确认你要使用的SqlServer版本,如果是2014,就要在nuget中添加microsoft.sqlserver.types.dll,使用12.0.4100.1这个版本,它会自动添加sqlservertypes文件夹到项目中,并自动添加一个Loader类,在Loader类中修改以下代码,指定让sqlserver使用sqlserver2014的版本使用sqlserver spatial:

public static void LoadNativeAssemblies(string rootApplicationPath)
{
var nativeBinaryPath = IntPtr.Size > 4
? Path.Combine(rootApplicationPath, @"SqlServerTypes\x64\")
: Path.Combine(rootApplicationPath, @"SqlServerTypes\x86\");

LoadNativeAssembly(nativeBinaryPath, "msvcr100.dll");
LoadNativeAssembly(nativeBinaryPath, "SqlServerSpatial120.dll");

}

sqlserverSpatial120.dll代表使用Sqlserver2014的sqlserverspatial功能,因为sqlserver是硬编码使用sqlserverspatial10或11的空间数据库功能,如果不指定版本,它默认去找sqlserverspatial10或11。

(2)在工程中,将sqlserverTypes文件夹中的SqlServerSpatial120.dll设置属性,“复制到输出目录”:始终复制。

(3)有以上设置后,开发时,可以正常使用dbGeography功能,但在部署时,还会提示无法找到sqlserverspatial10.dll,解决办法就是在配置文件中指定sqlserver Type的版本,在<runtime>配置节,添加以下属性设置:

<dependentAssembly>
<!--指定sqlserverType的版本-->
<assemblyIdentity name="Microsoft.SqlServer.Types" publicKeyToken="89845dcd8080cc91" culture="neutral" />
<bindingRedirect oldVersion="10.0.0.0" newVersion="12.0.0.0" />
</dependentAssembly>

提示:12.0.0代表sqlserver2014。

 

经过以上设置,开发和部署时,使用spatial功能时,就全解决了。

 

以上是关于EF连接Sqlserver2014,使用DBGeography时提示无法加载sqlserverspatial.dll的主要内容,如果未能解决你的问题,请参考以下文章

修改 EF的默认连接工厂为 Sql Server 而不是LocalDb

core版本使用ef连接数据库

锁定事务 (SQL Server + EF5)

是否可以为 MySql 和 SqlServer 提供 EF 上下文?

在Visual studio 2017中使用EF6连接MySQL

连接更新数据库命令的EF6问题