2

我在 Visual Studio 2010 中有一个面向 SQL Server 2012 的数据库项目,并且至少有一个存储过程使用新语法重新抛出错误(“THROW;”)

尝试从命令行构建项目,如下所示:

msbuild /t:Build MyDatabaseProject.dbproj

输出这个:

Microsoft (R) Build Engine Version 4.0.30319.1
[Microsoft .NET Framework, Version 4.0.30319.269]
Copyright (C) Microsoft Corporation 2007. All rights reserved.

Build started 28.08.2012 13:14:23.
Project "F:\My\Path\MyDatabaseProject.dbproj" on node 1 (Build target(s)).
DspBuild:
  Creating a model to represent the project...
  Loading project files...
  Building the project model and resolving object interdependencies...
  Validating the project model...
F:\MY\PATH\SCHEMA OBJECTS\SCHEMAS\DBO\PROGRAMMABILITY\STORED PROCEDURES\SOMEPROC.PROC.SQL(95,3,95,3): Build error SQL02010: Incorrect syntax near THROW. [F:\My\Path\MyDatabaseProject.dbproj]
...

我的猜测是我应该添加一个参数来指定 SQL Server 2012 T-SQL 方言,但我不确定这一点。

从 Visual Studio 构建项目没有任何问题。


更新:我不确定我有什么类型的项目。项目属性如下所示:

在此处输入图像描述

附加数据:

在此处输入图像描述

在此处输入图像描述

在此处输入图像描述

在此处输入图像描述

在此处输入图像描述

4

1 回答 1

3

看起来您正在使用仅支持 SQL Server 2008 的旧数据库项目类型。Visual Studio 2010 有一个支持 SQL Server 2012 的新数据库项目类型(具有非常通用的名称“SQL Server 数据库项目”)您可以将其作为最新版本的SQL Server Data Tools的一部分进行安装。

新项目类型需要不同的命令行语法,您可以在此处找到。

顺便说一句,Visual Studio 可以轻松地将现有的数据库项目转换为新的项目类型。

于 2012-08-28T19:10:04.410 回答