执行SQL语句脚本文件
发布日期:2021-09-02 05:58:48 浏览次数:1 分类:技术文章

本文共 1190 字,大约阅读时间需要 3 分钟。

       在项目中关于执行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;
                }
            }
        }

 

转载于:https://www.cnblogs.com/kevinGao/archive/2011/09/23/2186443.html

转载地址:https://blog.csdn.net/weixin_34138255/article/details/93766784 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:System.Timers.Timer与System.Windows.Forms.Timer 区别
下一篇:jsonp与ajax

发表评论

最新留言

初次前来,多多关照!
[***.217.46.12]2024年03月01日 04时01分08秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

java ip 范围内打卡_定位地理位置PHP判断员工打卡签到经纬度是否在打卡之内 2019-04-21
与java线程有关的,线程多少和什么有关?大神们表示有话要说! 2019-04-21
php正则表达式 匹配数字,正则表达式之匹配数字范围 2019-04-21
php中带?错误,参考-此错误在PHP中意味着什么? 2019-04-21
php生成链接列表,根据URL链接和抛文本生成链接<a>标签的PHP函数 2019-04-21
matlab里inline定义矩阵,Matlab中的inline函数_matlab中inline函数 2019-04-21
php html标签自定义属性,浅谈JS读取DOM对象(标签)的自定义属性 2019-04-21
如何使用matlab的siso,利用Matlab内建程式SISODesignTool完成系统分析(Matlab61)开启.PDF... 2019-04-21
php 实现 model层,Thinkhphp5控制器调用的Model层的方法总结 2019-04-21
matlab6.0序列号,MFC软件获取USB设备的制造商、产品、序列号 2019-04-21
matlab中多边形滤波器,几种常见空间滤波器MATLAB实现 2019-04-21
matlab fminimax 例子,Matlab应用实例(8)—fminimax 2019-04-21
php://filter利用条件,浅谈php://filter技巧 2019-04-21
mplayer-php,mplayer+smplayer 前后端播放器安装 2019-04-21
oracle昨日时间,。。今日,昨日,上周,本月,本年,按时间统计总金额 2019-04-21
php验证卡号,PHP验证信用卡卡号是否正确函数 2019-04-21
mpvue微信小程序动画_推荐两个微信小程序开发框架 2019-04-21
固态硬盘分为哪几种_零基础玩转固态硬盘 深度排雷 买SSD掌握这些就够了 2019-04-21
调python返回图片_Python异常处理,3个好习惯分享给你 2019-04-21
15拆解_收藏:15款劲芯微芯片无线充产品拆解 2019-04-21