C# 批量执行sql脚本

本文详细介绍了如何使用C#编程语言来批量执行SQL脚本,包括连接数据库、读取脚本文件、执行SQL语句等关键步骤,帮助开发者高效地更新和维护数据库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  public void GetFilePath()
        {
            string ConfigPath = System.AppDomain.CurrentDomain.BaseDirectory + "web.config";
            XmlDocument xmlDoc = new XmlDocument();
            xmlDoc.Load(ConfigPath);
            XmlNode root = xmlDoc.SelectSingleNode("configuration");

            //解析connectionStringItems
            XmlNode list = root.SelectSingleNode("connectionStringItems");
            //循环遍历数据库连接Items
            foreach (XmlNode item in list.ChildNodes)
            {
                string ConnStr = item.InnerText;

                //获取数据库字符串中所有信息
                SqlConnection conn = new SqlConnection(ConnStr);
                SqlConnectionStringBuilder sqlSb = new SqlConnectionStringBuilder(ConnStr);
                string userId = sqlSb.UserID;  //获取登录名
                string password = sqlSb.Password; //获取数据库密码
                string ServerIP = conn.DataSource; //获取数据库连接IP
                string DataBase = conn.Database; //获取数据库名字           

                var files = Directory.GetFiles(FilePath, "*.sql");
                foreach (var it in files)
                {
                    string sqlQuery = "sqlcmd.exe -U  " + userId + "  -P " + password + " -S " + ServerIP + " -d " + DataBase + " -i " + it + " ";
                    string result = ExeCommand(sqlQuery);
                }
            }
        }
        /// <summary>
        /// 执行sql语句方法
        /// </summary>
        /// <param name="commandText">SQL语句</param>
        /// <returns></returns>
        public static string ExeCommand(string commandText)
        {
            Process p = new Process();
            p.StartInfo.FileName = "cmd.exe";
            p.StartInfo.UseShellExecute = false;
            p.StartInfo.RedirectStandardInput = true;
            p.StartInfo.RedirectStandardOutput = true;
            p.StartInfo.RedirectStandardError = true;
            p.StartInfo.CreateNoWindow = true;
            string strOutput = null;
            try
            {
                p.Start();
                p.StandardInput.WriteLine(commandText);
                p.StandardInput.WriteLine("exit");
                strOutput = p.StandardOutput.ReadToEnd();
                p.WaitForExit();
                p.Close();
            }
            catch (Exception e)
            {
                strOutput = e.Message;
            }
            return strOutput;
        }

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值