Добавление Microsoft.SqlServer.Types
к существующему веб-проекту, чтобы мы могли использовать пространственные типы DBGeography
и DBGeometry
из NuGet, добавляли в проект собственные сборки и включали Loader
, который выглядит примерно так:
public class Utilities
{
[DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
private static extern IntPtr LoadLibrary(string libname);
/// <summary>
/// Loads the required native assemblies for the current architecture (x86 or x64)
/// </summary>
/// <param name="rootApplicationPath">
/// Root path of the current application. Use Server.MapPath(".") for ASP.NET applications
/// and AppDomain.CurrentDomain.BaseDirectory for desktop applications.
/// </param>
public static void LoadNativeAssemblies(string rootApplicationPath)
{
var nativeBinaryPath = IntPtr.Size > 4
? Path.Combine(rootApplicationPath, @"SqlServerTypes\x64\")
: Path.Combine(rootApplicationPath, @"SqlServerTypes\x86\");
LoadNativeAssembly(nativeBinaryPath, "msvcr120.dll");
LoadNativeAssembly(nativeBinaryPath, "SqlServerSpatial140.dll");
}
private static void LoadNativeAssembly(string nativeBinaryPath, string assemblyName)
{
var path = Path.Combine(nativeBinaryPath, assemblyName);
var ptr = LoadLibrary(path);
if (ptr == IntPtr.Zero)
{
throw new Exception(string.Format(
"Error loading {0} (ErrorCode: {1})",
assemblyName,
Marshal.GetLastWin32Error()));
}
}
}
Который затем должен вызываться из нашего global.asax.cs
следующим образом:
SqlProviderServices.SqlServerTypesAssemblyName =
"Microsoft.SqlServer.Types, Version=14.0.0.0, Culture=neutral, PublicKeyToken=89845dcd8080cc91";
SqlServerTypes.Utilities.LoadNativeAssemblies(Server.MapPath("~"));
(первая строка найдена только после некоторого копания).
Это все работаетхорошо локально и работает нормально после развертывания ... но проблема в том, что при повторном развертывании нашего проекта эти собственные сборки блокируются, и это нарушает сборку. Рабочий процесс должен быть остановлен и перезапущен до того, как может произойти развертывание, и это большая проблема.
Итак, мой вопрос, есть ли лучший способ справиться с этим? Файл readme.htm, который загружается с пакетом NuGet, предполагает, что вам необходимо развернуть собственные сборки на машине, на которой не установлены «Типы CLR системы для SQL Server» , но не совсем понятно, чтоЕсли вам что-то понадобится, вам нужно сделать это, и то, что вам, возможно, придется изменить, если вы это сделаете.