我正在使用 Microsoft Data-Tier Application framework基于 DacPackage 创建部署脚本目的。我正在尝试使用 Microsoft.SqlServer.Management.Smo.Server执行此脚本的类...
SqlConnection deployConnection = new SqlConnection(connBuilder.ToString());
deployConnection.Open();
Server server = new Server(new ServerConnection(deployConnection));
server.ConnectionContext.ExecuteNonQuery(deployScript);
但是,这个错误...
Unhandled Exception: Microsoft.SqlServer.Management.Common.ExecutionFailureException:
An exception occurred while executing a Transact-SQL statement or batch. --->
System.Data.SqlClient.SqlException: Incorrect syntax near ':'.
我知道这个问题的答案是我需要处于 SQLCMD 模式,但我不知道如何告诉我的 ServerConnection在所述模式下执行。
我想我的问题并不像我在标题中所说的那样具体。我真正需要做的是通过 .Net 框架执行从 DacPackage 生成的脚本。谁能帮我解决这个问题?
最佳答案
SQLCMD 模式命令不是 T-SQL 命令;它们仅适用于 SQL Server Management Studio (SSMS)/Visual Studio (VS) 和 SQLCMD.EXE。 SQLCMD 模式本质上是 SQLCMD.EXE 的工作方式,可以在 SSMS/VS 中手动启用;它是这些应用程序的一部分,而不是可以通过提供商完成的事情。
这些应用程序解释 SQLCMD 模式命令,但不会将它们传递给 SQL Server。 SQLCMD 模式命令首先被解析/执行(这是它们能够影响将要提交的 SQL 的方式),然后将 SQL 的最终版本提交给 SQL Server。
因此,SQL Server Data Tools (SSDT)/Visual Studio 生成的部署 SQL 脚本需要通过这三个程序之一运行。
由于您已经有了一个 .dacpac 文件,Microsoft 提供了几种发布您应该检查的文件的方法:
SqlPackage.exe 和 MSDeploy.exe。它们都在 Project-Oriented Database Development using Command-Line Tools 的 MSDN 页面上进行了描述.DacServices.Deploy()。这可以通过 DacServices Class 在 C# 中完成。 .您还可以通过 DacServices.GenerateDeployScript() 创建发布 SQL 脚本,但这不会改变上述情况,因为发布/部署 SQL 脚本,无论是从 Visual Studio“Publish {project_name}”还是 GenerateDeployScript() 生成的,都是同一个脚本。这意味着,它将具有 SQLCMD 模式的冒号命令,例如 :setvar 和 :on error exit 以及 SQLCMD 模式的变量,这至少会是在以下行中使用的 $(DatabaseName):
USE [$(DatabaseName)];
虽然可以通过设置 DacDeployOptions 来注释掉初始的 :setvar 行CommentOutSetVarDeclarations的属性(property)为 true,这仍然会留下 :on error exit 行以及用于 :setvar __IsSqlCmdEnabled "True" 的行检测是否已启用 SQLCMD 模式。就在这个特定的 :setvar 行之上是一条注释:
/*
Detect SQLCMD mode and disable script execution if SQLCMD mode is not supported.
To re-enable the script after enabling SQLCMD mode, execute the following:
SET NOEXEC OFF;
*/
所以他们真的打算让这个脚本只通过 SQLCMD 运行,无论是通过 DOS -> SQLCMD.EXE 还是 PowerShell -> Invoke-SqlCMD。
从技术上讲,可以生成部署脚本内容的字符串(而不是流)并通过 a) 删除任何冒号命令和 b) 替换 "$ (DatabaseName)”与您打算部署到的任何数据库。但是,我没有尝试过,我不推荐这样做,而且我不确定它是否适用于 SQL Server Data Tools 可以生成哪些部署脚本的所有情况。但这确实是一个选项。
此外,次要相关的是:您不需要 SMO 来运行 SQL 脚本。 SMO 是通过对象而不是直接通过 T-SQL 命令与 SQL Server 交互的方法。
编辑:
其他人尝试过但发现它不起作用的链接:
使生成的发布 SQL 脚本以编程方式工作的可能性:
SQLCMD.EXE -i filename.sql:http://msdn.microsoft.com/en-us/library/system.diagnostics.process.start(v=vs.110).aspx 关于c# - SQLCMD模式下的ServerConnection.ExecuteNonQuery,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26617247/
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
鉴于我有以下迁移:Sequel.migrationdoupdoalter_table:usersdoadd_column:is_admin,:default=>falseend#SequelrunsaDESCRIBEtablestatement,whenthemodelisloaded.#Atthispoint,itdoesnotknowthatusershaveais_adminflag.#Soitfails.@user=User.find(:email=>"admin@fancy-startup.example")@user.is_admin=true@user.save!ende
如何在ruby中调用C#dll? 最佳答案 我能想到几种可能性:为您的DLL编写(或找人编写)一个COM包装器,如果它还没有,则使用Ruby的WIN32OLE库来调用它;看看RubyCLR,其中一位作者是JohnLam,他继续在Microsoft从事IronRuby方面的工作。(估计不会再维护了,可能不支持.Net2.0以上的版本);正如其他地方已经提到的,看看使用IronRuby,如果这是您的技术选择。有一个主题是here.请注意,最后一篇文章实际上来自JohnLam(看起来像是2009年3月),他似乎很自在地断言RubyCL
我正在尝试在Ruby中复制Convert.ToBase64String()行为。这是我的C#代码:varsha1=newSHA1CryptoServiceProvider();varpasswordBytes=Encoding.UTF8.GetBytes("password");varpasswordHash=sha1.ComputeHash(passwordBytes);returnConvert.ToBase64String(passwordHash);//returns"W6ph5Mm5Pz8GgiULbPgzG37mj9g="当我在Ruby中尝试同样的事情时,我得到了相同sha
给定一个复杂的对象层次结构,幸运的是它不包含循环引用,我如何实现支持各种格式的序列化?我不是来讨论实际实现的。相反,我正在寻找可能会派上用场的设计模式提示。更准确地说:我正在使用Ruby,我想解析XML和JSON数据以构建复杂的对象层次结构。此外,应该可以将该层次结构序列化为JSON、XML和可能的HTML。我可以为此使用Builder模式吗?在任何提到的情况下,我都有某种结构化数据-无论是在内存中还是文本中-我想用它来构建其他东西。我认为将序列化逻辑与实际业务逻辑分开会很好,这样我以后就可以轻松支持多种XML格式。 最佳答案 我最
C#实现简易绘图工具一.引言实验目的:通过制作窗体应用程序(C#画图软件),熟悉基本的窗体设计过程以及控件设计,事件处理等,熟悉使用C#的winform窗体进行绘图的基本步骤,对于面向对象编程有更加深刻的体会.Tutorial任务设计一个具有基本功能的画图软件**·包括简单的新建文件,保存,重新绘图等功能**·实现一些基本图形的绘制,包括铅笔和基本形状等,学习橡皮工具的创建**·设计一个合理舒适的UI界面**注明:你可能需要先了解一些关于winform窗体应用程序绘图的基本知识,以及关于GDI+类和结构的知识二.实验环境Windows系统下的visualstudio2017C#窗体应用程序三.
了解Rails缓存如何工作的人可以真正帮助我。这是嵌套在Rails::Initializer.runblock中的代码:config.after_initializedoSomeClass.const_set'SOME_CONST','SOME_VAL'end现在,如果我运行script/server并发出请求,一切都很好。然而,在我的Rails应用程序的第二个请求中,一切都因单元化常量错误而变得糟糕。在生产模式下,我可以成功发出第二个请求,这意味着常量仍然存在。我已通过将以上内容更改为以下内容来解决问题:config.after_initializedorequire'some_cl
我经常迷上ruby的一件事是递归模式。例如,假设我有一个数组,它可能包含无限深度的数组作为元素。所以,例如:my_array=[1,[2,3,[4,5,[6,7]]]]我想创建一个方法,可以将数组展平为[1,2,3,4,5,6,7]。我知道.flatten可以完成这项工作,但这个问题是作为我经常遇到的递归问题的一个例子-因此我试图找到一个更可重用的解决方案。简而言之-我猜这种事情有一个标准模式,但我想不出任何特别优雅的东西。任何想法表示赞赏 最佳答案 递归是一种方法,它不依赖于语言。您在编写算法时要考虑两种情况:再次调用函数的情
这应该是一个简单的问题,但我找不到任何相关信息。给定一个Ruby中的正则表达式,对于每个匹配项,我需要检索匹配的模式$1、$2,但我还需要匹配位置。我知道=~运算符为我提供了第一个匹配项的位置,而string.scan(/regex/)为我提供了所有匹配模式。如果可能,我需要在同一步骤中获得两个结果。 最佳答案 MatchDatastring.scan(regex)do$1#Patternatfirstposition$2#Patternatsecondposition$~.offset(1)#Startingandendingpo