我无法让Sql Server localdb连接在没有安装SqlServer Express的计算机上工作

问题描述 投票:22回答:5

我有一个使用Visual Studio 2012编写的C#控制台应用程序。在应用程序中,我使用Sql Server localdb连接到数据库来存储信息。这在几台计算机上运行正常,所有计算机都安装了Visual Studio。

我想部署一个只需要安装Sql Server Express LocalDB的程序,而不是更大的Sql Server Express。但是,我的应用程序未在目标计算机上运行。我在目标计算机上安装了Sql Server Express LocalDB 2014。我可以使用命令行使用sqllocaldb运行命令来验证它是否已安装并正在运行。

C:\Users\someuser\Desktop\Debug>sqllocaldb v
Microsoft SQL Server 2014 (12.0.2000.8)`

但是,当我在同一台目标计算机上运行我的应用程序时,出现以下错误。

C:\ Users \用户SomeUser的\桌面\调试> Testing_Console 11:21:07,912 [1] INFO TestingConsole.Program - 当前目录是C:\ Users \ someuser \ Desktop \ Debug 额外信息:( null) 未处理的异常:System.Data.SqlClient.SqlException:建立与SQL Server的连接时发生与网络相关或特定于实例的错误。服务器未找到或无法访问。验证实例名称是否正确,以及SQL Server是否配置为允许远程连接。 (提供程序:SQL网络接口,错误:50 - 发生本地数据库运行时错误。无法创建自动实例。请参阅Windows应用程序事件日志以获取错误详细信息。

以下是我的app.config文件的开头,我在其中定义连接字符串。我已经尝试将直接文件路径放入LM文件,但这并没有解决问题。然而,这是预期的,因为该程序可以在安装了Visual Studio的计算机上的任何目录中运行。

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>
  <connectionStrings>
    <add name="KomoLM_Console.Properties.Settings.LMConnectionString"
      providerName="System.Data.SqlClient"
      connectionString="Data Source=(LocalDB)\v11.0;AttachDbFilename=|DataDirectory|\LM.mdf;Integrated Security=True;MultipleActiveResultSets=True"
 />
  </connectionStrings>
  <startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
  </startup>

我不知道这个问题是否只与安装了SQL Server Express LocalDB 2014有关。谁能告诉我我的问题可能是什么?

c# sql-server visual-studio-2012 localdb sql-server-2014-express
5个回答
29
投票

问题与安装Sql Server Express LocalDB 2014而不是2012年有关。使用该版本,MS已更改连接字符串要求。而不是Data Source=(LocalDB)\V11.0,连接字符串是Data Source=(LocalDB)\MSSQLLocalDB。更改连接字符串后,程序在仅安装了LocalDB 2014的计算机上正常运行。这是一篇关于它的文章的链接:https://connect.microsoft.com/SQLServer/feedback/details/845278/sql-server-2014-express-localdb-does-not-create-automatic-instance-v12-0

http://msdn.microsoft.com/en-us/library/hh510202(v=sql.120).aspx


7
投票

使用“Data Source =(LocalDB)\ MSSQLLocalDB”也不适用于我。我不得不访问databasse使用“Data Source =(LocalDB)\ V12.0”,并且为了工作,我需要首先运行此命令“sqllocaldb create”v12.0“。有关此链接的更多详细信息https://dyball.wordpress.com/2014/04/28/sql-2014-localdb-error-cannot-connect-to-locaidbv12-o/


3
投票

您需要确保已安装.NET Framework 4.0,同样重要的是,还要安装.NET Framework 4.0.2更新(KB#2544514)。

一旦您的系统是最新的,您可以从以下位置下载SqlLocalDb安装程序:

http://www.microsoft.com/en-us/download/details.aspx?id=29062


2
投票

具有连接字符串(LocalDB)\v11.0的构建将与此链接上给出的localDB ENU\x64\SqlLocalDB.MSI一起使用Download SqlLocalDB

我在没有安装Visual Studio的目标系统上试过这个。此构建将与仅安装SqlLocalDB.msi的数据库连接。无需在目标系统上安装SqlExpress


1
投票

问题是当您同时安装Visual Studio 2013和Visual Studio 2017时,安装了两个版本的loacal数据库。

Visual Studio 2013 - (localdb)\ v11.0 Microsoft SQL Server 2012(SP1) - 11.0.3000.0(X64)2012年10月19日13:38:57版权所有(c)Microsoft Corporation Express Edition(64位)在Windows NT 6.2上(建立9200:)

Visual Studio 2017 - (localdb)\ MSSQLLOCALDB Microsoft SQL Server 2016(SP1)(KB3182545) - 13.0.4001.0(X64)2016年10月28日18:17:30版权所有(c)Microsoft Corporation Express Edition(64位)在Windows 10上Pro 6.3(Build 17134 :)

在安装Visual Studio 2017之前,我能够连接到(localdb)\ v11.0,但在安装Visual Studio 2017后,我无法连接到以前版本的SQL Express(localdb)\ v11.0,但我能够使用C#连接到(localdb)\ MSSQLLOCALDB。我可以从SQL Server Management Studio连接到它们,没有任何问题。

© www.soinside.com 2019 - 2024. All rights reserved.