菜菜吃菜 2022-04-13 17:58 采纳率: 57.5%
浏览 74
已结题

System.Data.SqlClient.SqlException:““GO”附近有语法错误。


sb.Append("USE 98");
               sb.Append(@"IF EXISTS(SELECT * FROM sys.procedures WHERE name = '98') DROP PROCEDURE 98");
               sb.Append(@"GO ");
               sb.Append(@"CREATE PROC 98 @ID INT, @Time datetime, @Un bigint, @Data VARCHAR(50) AS BEGIN UPDATE Data20220401 SET DataFlag = @Data, ");
               sb.Append("ID =@ID WHEREId = @Id AND DATEDIFF(ss, Time, @Time) = 0 END");
               string KJil = sb.ToString();

                comStr = new SqlCommand(KJil, conStr);//SQL语句执行对象,第一个参数是要执行的语句,第二个是数据库连接对象
               
               comStr.ExecuteNonQuery();

想用c# 提交存储事务 System.Data.SqlClient.SqlException:““GO”附近有语法错误,提示这个错误,GO在语句中无法执行

  • 写回答

2条回答 默认 最新

  • 歇歇 2022-04-13 21:56
    关注

    Go需要单独执行

    sb.Append("USE 98");
                   sb.Append(@"IF EXISTS(SELECT * FROM sys.procedures WHERE name = '98') DROP PROCEDURE 98");
     string KJil = sb.ToString();
    comStr = new SqlCommand(KJil, conStr);
    comStr.ExecuteNonQuery();
    comStr = new SqlCommand("Go", conStr);
    comStr.ExecuteNonQuery();
    sb.delete( 0, sb.length() );
    sb.Append(@"CREATE PROC 98 @ID INT, @Time datetime, @Un bigint, @Data VARCHAR(50) AS BEGIN UPDATE Data20220401 SET DataFlag = @Data, ");
    sb.Append("ID =@ID WHEREId = @Id AND DATEDIFF(ss, Time, @Time) = 0 END");
    KJil = sb.ToString();
    comStr = new SqlCommand(KJil, conStr);
    comStr.ExecuteNonQuery();
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月22日
  • 已采纳回答 4月14日
  • 创建了问题 4月13日

悬赏问题

  • ¥30 关于#python#的问题:我想要的是这79个大特征对于房屋售价的最大的影响前十名(相关搜索:随机森林)
  • ¥15 使用matlab计算自定义特殊函数的二重积分,改变积分顺序所得的结果不同的问题?
  • ¥15 mysql做碎片化处理老是报错怎么办
  • ¥15 如何正确在vs2010中初始化map对象
  • ¥30 mmdet3d模型部署问题
  • ¥15 comsol仿真反射率、吸收率时峰值位置和深度不对!
  • ¥30 Visual Studio找不到sdk,如何解决?
  • ¥15 labview与机器之间网口通信发送指令
  • ¥15 迪杰斯特拉算法,考虑时延,带宽
  • ¥30 C#提交json字符串给http服务器