【关于SqlCommand执行脚本和查询分析器执行脚本的区别】

HolyPlace 2010-05-28 11:42:23
我现在想通过C#读取一个sql脚本做程序的升级,我的脚本在查询分析器里面可以正常执行,但是通过SqlCommand以Text的形式执行就不行了,有的地方说去掉Go,有的说要加 ; ,修改之后可以执行,但是还是不稳定,有的存储过程中的参数会报错。

为了找到一个安全的执行方法,不知道大家有没有这方面的研究?
...全文
130 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
winner2050 2010-05-28
  • 打赏
  • 举报
回复
/// <summary>
/// Sql文本转换为批量执行Sql脚本
/// </summary>
/// <param name="sr"></param>
/// <returns></returns>
static public List<string> SqlText2SqlList(System.IO.StreamReader sr)
{
List<string> SqlList = new List<string>();
string commandText = "";
string varLine = "";
while (sr.Peek() > -1)
{
varLine = sr.ReadLine();
if (varLine.Length == 0)
{
continue;
}
if (varLine != "GO")
{
commandText += varLine;

commandText += "\r\n";
}
else
{
SqlList.Add(commandText);
commandText = "";
}
}
return SqlList;
}
HolyPlace 2010-05-28
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 winner2050 的回复:]

要自己作个分隔sql代码的函数才行。
一般用GO 作分隔就可以了。
直接读取文本里面的sql代码是不行的。
[/Quote]

你的意思是必须一段段的执行?GO分隔是查询分析器里面使用的吧
winner2050 2010-05-28
  • 打赏
  • 举报
回复
要自己作个分隔sql代码的函数才行。
一般用GO 作分隔就可以了。
直接读取文本里面的sql代码是不行的。
aluogang 2010-05-28
  • 打赏
  • 举报
回复
帮顶,学习!
HolyPlace 2010-05-28
  • 打赏
  • 举报
回复
自己沙发
HolyPlace 2010-05-28
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 gs670gs 的回复:]

把你的新建查询的内容放到存储过程里面呢?直接执行那个存储过程呢?
[/Quote]
我所要执行不仅仅是存储过程
小黑哥gs 2010-05-28
  • 打赏
  • 举报
回复
把你的新建查询的内容放到存储过程里面呢?直接执行那个存储过程呢?
HolyPlace 2010-05-28
  • 打赏
  • 举报
回复
这个想法方法不错,试试
测试管理与QualityCenter培训手册 1、测试流程管理、测试度量方法 按照尽早进行测试的原则,测试人员应该在需求阶段就介入,并贯穿软件开发的全过程。就测试过程本身而言,应该包含以s下几个阶段。  -测试需求的分析和确定。  -测试计划。  -测试设计。  -测试执行。  -测试记录和缺陷跟踪。  -回归测试。  -测试总结和报告。 一个好的测试管理工具应该能把以上几个阶段都管理起来。 测试人员每时每刻都在度量别人的工作成果,而测试人员的工作成果又由谁来度量呢?度量的标准和依据是什么呢?软件测试的度量是测试管理必须仔细思考的问题。缺乏尺度会让测试失去平衡,缺乏标准会让测试工作难以衡量。 2、如何搭建测试管理平台? 首要问题是流程的规范化。 (1) 测试进入和退出标准。 (2) 协作流程。 (3) 缺陷跟踪管理流程。 (4) 工具平台的引入。 目前主流测试管理平台与缺陷跟踪工具: 3、QC(Quality Center)介绍 QC标准测试管理流程 QC支持的应用服务器:Jboss、WebLogic、WebSphere QC支持的数据库:Oracle、SQLServer QC支持的操作系统:Windows、Linux、Solaris 支持群集: 服务器端硬件和数据库要求: Windows: Linux: Solaris: 客户端系统要求: 练习1:安装QC 详见《Mercury Quality Center 9.0 Installation Guide》 Win2003+SQLServerSp4+QC9.0安装示例 1、安装Windows Server 2003 Enterprise Edition、安装IIS邮件服务器 2、安装SQL Server 2000、打上补丁Sp4 安装好SQL Server 2000后注意启动SQLServer服务器 3、安装QC9.0 服务器名称也可以是IP地址 4、启动QC9.0 5、QC9.0安装问题解决 - JBOSS启动不了 原因:8080端口被其他应用程序占用。 用netstat查看谁占用了8080端口 netstat -ano 解决办法1:修改其他程序的端口使用 解决办法2:修改JBOSS的启动端口 JBOSS_HOME\server\default\deploy\jbossweb-tomcat55.sar\server.xml 6、修改IP地址后不能登录QC 解决办法: 在C:\Program Files\Mercury\Quality Center\jboss\server\default\deploy目录下找到10sabin.war 进入10sabin.war\WEB-INF,修改siteadmin.xml中的IP地址: 修改数据库中的数据: 修改后可以登陆 但是还需要修改以前Project的数据库连接属性 否则会提示错误 然后还要修改 C:\Program Files\Mercury\Quality Center\repository\qc中的dbcon.txt: qcsiteadmin_db@192.168.1.12.1433. 还有 C:\Program Files\Mercury\Quality Center\repository\qc\Default\QualityCenter_Demo_db中的dbid.xml 192.168.1.12 7、Mercury Tours 样例程序 启动:http://192.168.1.2:8080/mtours 注意安装JVM才能“View Calendar” 4、创建和定义测试需求、测试需求管理、跟踪 定义需求 1、查看需求 视图->需求树 2、添加需求 需求->新建需求 输入以下内容 3、添加子需求项 查看需求 ZooIn : CTRL + I ZooOut : CTRL + O 视图->编号 视图->需求网格 视图->筛选/排序->设置筛选器/排序 设置排序字段 设置过滤条件 修改需求 拷贝需求项Cruise Reservation 重命名需求项Cruise Reservation_Copy_1为Hotel Reservation 移动需求项

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧