码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2017-06-07 12:37:13      阅读:504      评论:0      收藏:0      [点我收藏+]

标签:publickey   目录   sql   项目   ken   文件   int   输出   ogr   

(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

标签:publickey   目录   sql   项目   ken   文件   int   输出   ogr   

原文地址:http://www.cnblogs.com/SimpleGIS/p/6955915.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!