执行SQL语句脚本文件

       在项目中关于执行SQL语句的底层方法的通用类很多,但是很少有提供执行SQL脚本的的方法,曾经在项目中有功能需要能直接执行SQL脚本的方法,

经过项目的实践检验,方法比较实用,现在将代码贴出来给大家分享下:

/// <summary>
        /// 执行SQL语句脚本文件(带注释,带Go)
        /// </summary>
        /// <param name="sqlFileName">sql脚本文件路径</param>
        public static int ExecuteSQLFile(String sqlFileName)
        {
            int icount = 0;
            using (SqlConnection connecction = new SqlConnection(connectionString))
            {
            FileStream stream = new FileStream(sqlFileName, FileMode.Open);
            StreamReader reader = new StreamReader(stream, Encoding.GetEncoding("gb2312"));
                try
                {
                    SqlCommand command = connecction.CreateCommand();
                    connecction.Open();
                    //读取文件
                   
                    StringBuilder builder = new StringBuilder();
                    String strLine = "";
                    while ((strLine = reader.ReadLine()) != null)
                    {
                        if (strLine.Trim().ToUpper() != @"GO")
                        {
                            builder.AppendLine(strLine);
                        }
                        else
                        {
                            command.CommandText = builder.ToString();
                            icount = command.ExecuteNonQuery();
                            builder.Remove(0, builder.Length);
                        }
                    }
                    command.CommandText = builder.ToString();
                    icount = command.ExecuteNonQuery();
                    builder.Remove(0, builder.Length);
                    reader.Close();
                    stream.Close();
                    return icount;
                }
                catch
                {
                    reader.Close();
                    stream.Close();
                    icount = 0;
                    return icount;
                }
            }
        }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值