Как проверить код С#, если в настоящее время установлен LocalDB? также, как проверить, представлен ли SQLNCLI11 в системе?
SQL2012 LocalDB: как проверить С#, если он установлен в настоящий момент?
Ответ 1
Проверьте, установлен ли LocalDB, ищите этот раздел реестра:
[HKLM\SOFTWARE\Microsoft\Microsoft SQL Server Local DB\Installed Versions\11.0]
SQLNCLI11 - проверьте версию файла и наличие этого файла: C:\WINDOWS\system32\sqlncli.dll
Ответ 2
Вот пример VB.NET для LOCALDB
Public Shared Function CheckLocalDBExists() As Boolean
Dim s As String = ""
Dim reg As RegistryKey
Dim rtn As Boolean = False
reg = Registry.LocalMachine.OpenSubKey("SOFTWARE\Microsoft\Microsoft SQL Server Local DB\Installed Versions\12.0", True)
Try
s = reg.GetValue("ParentInstance", "").ToString
reg.Close()
Catch ex As Exception
s = Nothing
End Try
'MessageBox.Show(s)
If s = "MSSQL12E.LOCALDB" Then
rtn = True
End If
Return rtn
End Function
Ответ 3
Я использую ответ на этот вопрос
для проверки существования sqllocaldb.exe
Так же:
public static bool IsLocalDBInstalled()
{
return ExistsOnPath("SqlLocalDB.exe"); ;
}
public static bool ExistsOnPath(string fileName)
{
return GetFullPath(fileName) != null;
}
public static string GetFullPath(string fileName)
{
if (File.Exists(fileName))
return Path.GetFullPath(fileName);
var values = Environment.GetEnvironmentVariable("PATH");
foreach (var path in values.Split(';'))
{
var fullPath = Path.Combine(path, fileName);
if (File.Exists(fullPath))
return fullPath;
}
return null;
}