C#執行sql文件 運行sql文件


 private void metroButton2_Click(object sender, EventArgs e)
        {
            string[] contens = new string[0];
            string FileNameSql = "";
            string templateFile = AppDomain.CurrentDomain.BaseDirectory;//程序文件目錄
            bool file_b = false;//默認txt文件不存在
            if (Directory.Exists(templateFile))//若文件夾存在
            {
                FileNameSql= templateFile + "\\創建檔案條目表.txt";
                file_b = File.Exists(templateFile + "\\創建檔案條目表.txt");//文件是否存在
                if (file_b)
                {
                    contens = File.ReadAllLines(templateFile + "\\創建檔案條目表.txt");//存在讀取這個txt
                }
            }

           //獲取到數據庫連接信息
            ExecuteCommand(GetSqlFile(FileNameSql, ""),DaoFactory.NewSJDao(Common.g_DataSource));
            MessageBox.Show("創建案卷表和卷內表成功!");
        }

 

        /// <summary>
        /// 讀取文件並且修改
        /// </summary>
        /// <param name="varFileName">文件路徑</param>
        /// <param name="dbname">數據庫表名</param>
        /// <returns></returns>
        public  ArrayList GetSqlFile(string varFileName, string dbname)
        {
            ArrayList alSql = new ArrayList();
            if (!File.Exists(varFileName))
            {
                return alSql;
            }
            StreamReader rs = new StreamReader(varFileName, System.Text.Encoding.Default);//注意編碼
            string commandText = "";
            string varLine = "";
            while (rs.Peek() > -1)
            {
                varLine = rs.ReadLine();
                if (varLine == "")
                {
                    continue;
                }
                if (varLine != "GO" && varLine != "go")
                {
                    commandText += varLine;
                    commandText = commandText.Replace("@database_name=N'dbhr'", string.Format("@database_name=N'{0}'", dbname));
                    commandText += "\r\n";
                }
                else
                {
                     //將@ArchvTable和@ArchvFileTable替換成案卷表名和卷內表名
                    string pcom = "";
                    if(commandText.Contains("@ArchvTable")|| commandText.Contains("@ArchvFileTable"))
                    {
                        pcom= commandText.Replace("@ArchvTable", Common.g_QXPZAJ);
                        pcom = pcom.Replace("@ArchvFileTable", Common.g_QXPZJN);
                    }
                    alSql.Add(pcom);
                    commandText = "";
                }
            }
            rs.Close();
            return alSql;
        }
 
        /// <summary>
        /// 連接數據庫表並執行文件中的sql語句
        /// </summary>
        /// <param name="varSqlList"></param>
        /// <param name="connString"></param>
        public static void ExecuteCommand(ArrayList varSqlList, string connString)
        {
            SqlConnection MyConnection = new SqlConnection(connString);
            MyConnection.Open();
            SqlTransaction varTrans = MyConnection.BeginTransaction();
            SqlCommand command = new SqlCommand();
            command.Connection = MyConnection;
            command.Transaction = varTrans;
            try
            {
                foreach (string varcommandText in varSqlList)
                {
                    command.CommandText = varcommandText;
                    command.ExecuteNonQuery();
                }
                varTrans.Commit();
            }
            catch (Exception ex)
            {
                varTrans.Rollback();
                throw ex;
            }
            finally
            {
                MyConnection.Close();
            }
        }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM