26

我有一个使用 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\Desktop\Debug>Testing_Console
11:21:07,912 [1] INFO TestingConsole.Program - 当前目录是 C:\Users\someuser\Desktop\Debug
额外信息:(空)


未处理的异常: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 有关。谁能告诉我我的问题可能是什么?

4

5 回答 5

34

问题与安装 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

于 2015-01-07T22:53:00.820 回答
8

使用“Data Source=(LocalDB)\MSSQLLocalDB”对我也不起作用。我必须使用“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/

于 2015-12-27T02:25:14.203 回答
4

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

系统更新后,您可以从以下位置下载 SqlLocalDb 安装程序:

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

于 2015-07-10T16:31:22.130 回答
2

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

Visual Studio 2013 - (localdb)\v11.0 Microsoft SQL Server 2012 (SP1) - 11.0.3000.0 (X64) Oct 19 2012 13:38:57 版权所有 (c) Microsoft Corporation Express Edition (64-bit) o​​n Windows NT 6.2 (构建 9200:)

Visual Studio 2017 - (localdb)\MSSQLLOCALDB Microsoft SQL Server 2016 (SP1) (KB3182545) - 13.0.4001.0 (X64) Oct 28 2016 18:17:30 版权所有 (c) Microsoft Corporation Express Edition (64-bit) o​​n Windows 10专业版 6.3(内部版本 17134:)

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

于 2019-03-06T16:46:08.637 回答
2

具有连接字符串的构建将与此链接上给出(LocalDB)\v11.0的 localDB 一起工作下载 SqlLocalDBENU\x64\SqlLocalDB.MSI

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

于 2016-05-11T04:56:46.857 回答