无法打开,因为它是版本852.此服务器支持版本782及更早版本

我正在使用Visual Studio 2017和SQL Server 2014.在将数据库文件附加到Visual Studio时,我收到此错误:

添加数据库连接

升级文件后,我使用了这个连接字符串

   

它在我的机器上工作正常,但在客户端机器上,弹出一个错误说

无法打开,因为它是版本852.此服务器支持版本782及更早版本

虽然我在客户端安装了SQL Server 2016本地数据库,但我仍然无法摆脱它。

我的第二个问题是:数据库文件不兼容的SQL Server的当前实例是什么?

图1 在此处输入图像描述

您的计算机上似乎有多个不同版本的SQL Server实例。

对于“完整版”版本(Express和up),您可以通过查看SQL Server配置管理器来查看它们的版本:

对于SQL Server的“LocalDB”版本(面向开发人员的版本),您可以使用sqllocaldb命令行工具。

使用此命令概述机器上的内容:

 C:\> sqllocaldb i MSSQLLocalDB v11.0 

然后,您可以使用details命令检查各个实例:

 C:\> sqllocaldb i mssqllocaldb Name: mssqllocaldb Version: 13.1.4206.0 Shared name: Owner: MSE-PC-02\Marc Auto-create: Yes State: Stopped Last start time: 27.08.2017 12:24:45 Instance pipe name: C:\> sqllocaldb i v11.0 Name: v11.0 Version: 11.0.3000.0 Shared name: Owner: MSE-PC-02\Marc Auto-create: Yes State: Stopped Last start time: 26.08.2017 15:41:18 Instance pipe name: 

因此,这告诉您有两个可用的SQL Server LocalDB实例 – mssqllocaldb是版本13.1(SQL Server 2016),而v11.0实例是版本11.0(SQL Server 2012)。

因此,如果要将.mdf文件附加到这两个实例中的任何一个,您只需选择正确的文件即可使其与您想要的版本一起使用。 一旦你将数据库文件“升级”到更新版本的SQL Server(如2016年 – 内部数据库版本852),你就永远不会回去 – 没有办法分离/附加,备份/恢复或其他方式获取那些二进制文件到旧版本的SQL Server。 您必须将新数据库文件的结构(可能还有数据)编写为.sql文件,并在旧版本上运行。

版本852是SQL Server 2016,版本782是SQL Server 2014.可以在此Microsoft页面找到版本的良好参考。

根据您的解释,这应该是版本782 DB。 由于它是版本852 DB,这意味着它是使用SQL Server 2016而不是SQL Server 2014升级的。因此,您应该检查在本地/ dev机器上运行的所有SQL Server版本,以确认只有SQL Server 2014是在使用中,而不是(可能)由VS 2017安装的SQL Server 2016。

此外,听起来您的最终用户版本是2014年,而不是2016年。如果当前数据库是SQL Server 2014模式数据库,这可能是一个问题。 在连接数据库之前尝试显式连接到TempDB。 (注意:这是我遇到2014/2016不兼容时必须要做的事情,但我不记得实际问题是什么。)

如果您希望项目生成可以在客户端计算机上附加的SQL Server 2014数据库,则必须在计算机上创建服务器实例。 为此,请以管理员模式打开命令行,然后输入命令“ sqllocaldb create v12.0 12.0 ”。 这将在12.0版SQL Server 2014中创建一个名为“v12.0”的服务器实例。

如果尚未启动服务器,则必须使用命令“ sqllocaldb start v12.0启动服务器。

现在你必须像这样改变你的conectionString:

    

也许您已经为app.config添加了一些参数