批量執行sql腳本(dos,sqlcmd),實現數據庫升級,本地必須有數據庫

<img src="" alt="" />
<span style="color:#6666cc;">上面是軟件的界面,程序必須生成之後用管理員的 身份運行.exe文件,因爲此處運行的是dos命令,或者用管理員的身份與運行VS之後再打開程序也是可以的,這樣的好處是可以進行跟蹤調試。</span>
</pre><pre name="code" class="html"><span style="color:#6666cc;">代碼實現的功能是:將數據庫的腳本存放在該程序的debug下面存放在</span><span style="color: rgb(102, 102, 204); ">UpgradeScripts文件夾中,然後執行程序,輸入用戶名,密碼,數據源和升級模式,之後,完成數據庫的升級。
當然在執行時,腳本的格式必須是有的,和你數據庫中的表中存放的升級記錄中的表是一直的,這樣是最好的。
<img src="" alt="" /><img src="" alt="" />
</span>
<span style="color:#6666cc;">這樣做是因爲在下面我要覈對版本號,然後來確定要升級的腳本都有哪個。</span>
<span style="color:#6666cc;">此處獲取腳本名稱有一個很好的辦法,就是</span><span style="color: rgb(102, 102, 204); ">String[] fn = Directory.GetFiles("UpgradeScripts");這個 方法是用之後,fn中存放的就是該文件夾下所有的數據庫腳本的名字,而且是按照一定順序來進行排列的,這也就省掉了一些排序的功能。</span>
<span style="color: rgb(102, 102, 204); ">
</span>
<span style="color:#6666cc;">下面的重點還有一處是</span><pre name="code" class="html">string commondstr = "SQLCMD -U " + textBox1.Text + " -P " + textBox2.Text + " -S " + textBox3.Text + " -d master -i " + Application.StartupPath + "\\UpgradeScripts\\";
此處是dos命令,這樣實現的好處是,範圍就不會侷限在本地,因爲數據源是自己輸入的,所以很大程度的擴大了使用範圍。
</pre><pre name="code" class="html"><pre name="code" class="html" style="color: rgb(102, 102, 204); "> Application.StartupPath  這句話獲取的是當前執行程序的根目錄,知道debug下面的目錄,這樣方便了我們獲取路徑,這樣隨意軟件包放在哪裏都不會影響路徑的拼裝。

</pre><pre>
</pre><pre name="code" class="html">using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Drawing;
using System.Data;
using System.Text;
using System.Windows.Forms;
using System.IO;
using System.Data.SqlClient;
using System.Diagnostics;
using System.Threading;
using Kyee.Utils;


namespace View
{
    public partial class DbUpgrade : UserControl
    {
        string[] sqlFileName = new string[0];//數組的初始化
        int[] sqlFlieCode = new int[0];
        string currentVerCode = "";//當前版本號E:\bedcard\source\牀頭卡集成管理平臺\牀頭卡集成管理平臺\View\bin\Debug\
        System.Data.SqlClient.SqlConnection sqlConn = new System.Data.SqlClient.SqlConnection();


        /// <summary>
        /// 主函數,程序入口
        /// </summary>
        public DbUpgrade()
        {
            InitializeComponent();
            saveDataRadio.Checked = true;
            modelPic.BackgroundImage = Image.FromFile(@"images/upgrade_model_pic.png");
            userNamePanel.BackgroundImage = Image.FromFile(@"images/upgrade_user_panel.png");
            userPwdPanel.BackgroundImage = Image.FromFile(@"images/upgrade_user_panel.png");
            dataSourcePanel.BackgroundImage = Image.FromFile(@"images/upgrade_user_panel.png");
            upgradePic.BackgroundImage = Image.FromFile(@"images/upgrade_left_pic.png");
        }


        /// <summary>
        /// 保留數據模式
        /// 升級模式的選擇問題
        /// 兩者只能選其一
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void saveDataRadio_CheckStateChanged(object sender, EventArgs e)
        {
            if (saveDataRadio.Checked)
            {
                newCreateRadio.Checked = false;
            }
            else
            {
                newCreateRadio.Checked = true;
            }
        }


        /// <summary>
        /// 重新創建模式
        /// 升級模式的選擇問題
        /// 兩者只能選其一
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void newCreateRadio_CheckStateChanged(object sender, EventArgs e)
        {
            if(newCreateRadio.Checked)
            {
               saveDataRadio.Checked = false;
            }
            else
            {
                saveDataRadio.Checked = true;
            }
        }


        /// <summary>
        /// 執行升級
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void upgradEexecutBt_Click(object sender, EventArgs e)
        {
            sqlFileName = Directory.GetFiles(Application.StartupPath.Substring(0, Application.StartupPath.LastIndexOf("\\") - 3) + "components\\db\\scripts");


            if (userName.Text != "" && userPwd.Text != "" && dataSource.Text != "")
            {
                if (checkSqlConnection())
                {
                    if (saveDataRadio.Checked)
                    {
                        saveDataRadioUpgrade();
                    }
                    else if (newCreateRadio.Checked)
                    {
                        newCreateRadioUpgrade();
                        System.Data.SqlClient.SqlConnection myConn = new System.Data.SqlClient.SqlConnection();
                        myConn.ConnectionString = groupConString(dataSource.Text, "bedcardSystem", userName.Text, userPwd.Text);
                        myConn.Open();
                        writeVerCodeToConfig(myConn);
                    }
                    else
                    {
                        MessageBox.Show("請選擇一個升級模式!", "提示");
                        sqlConn.Close();
                    }
                }
            }
            else
            {
                MessageBox.Show("信息請填寫完整!", "提示");
                sqlConn.Close();
            }
        }


        /// </summary>
        /// <param name="source">服務器名稱</param>
        /// <param name="initialCatalog">數據庫</param>
        /// <param name="userID">登錄名</param>
        /// <param name="password">密碼</param>
        /// <returns>拼接後的連接字符串</returns>
        public string groupConString(string source, string initialCatalog, string userID, string password)
        {
            String connectionString = "";
            try
            {
                connectionString = "server=" + source + ";uid=" + userID + ";pwd=" + password + ";database=" + initialCatalog;
            }
            catch (Exception ex)
            {
                connectionString = "";
                throw ex;
            }
            return connectionString;
        }


        /// <summary>
        /// 說明:切換到當前已經存在的數據庫
        /// 檢查該數據庫中的升級記錄表是否存在
        /// 存在則進行“保留數據”升級
        /// 否則進行“重新創建”升級
        /// </summary>
        /// <returns></returns>
        private void upgrade(string databaseName, string source, string userID, string password)
        {
            try
            {
                string connectionString = groupConString(source, databaseName, userID, password);
                SqlConnection myConn = new SqlConnection();
                SqlDataReader sdataReader = null;
                myConn = new SqlConnection(connectionString);
                string getDbaseNamesSqlStr = "SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[BEDCARD_UPGRADE_RECORD]') AND type in (N'U')";
                SqlCommand selectDatabaseNamesCommand = new SqlCommand(getDbaseNamesSqlStr, myConn);
                myConn.Open();
                sdataReader = selectDatabaseNamesCommand.ExecuteReader();
                if (sdataReader.Read())
                {
                    //若判斷當前爲服務器數據庫,則檢查版本信息
                    getCurrentVerCode(connectionString);
                    string name;
                    int i = 0;
                    for (i = 0; i < sqlFileName.Length; i++)
                    {
                        name = getSqlFileName(i);
                        if (name == currentVerCode)       //當前版本
                        {
                            break;
                        }
                    }
                    try
                    {
                        sdataReader.Close();
                        for (int k = i + 1; k < sqlFileName.Length; k++)
                        {
                            importSqlFile(sqlFileName[k], 10);
                        }
                        writeVerCodeToConfig(myConn);
                        MessageBox.Show("數據庫升級完成(保留原數據)", "提示");
                    }
                    catch (Exception ex)
                    {
                        throw ex;
                    }
                }
                else
                {
                    if (MessageBox.Show("該版本太低,沒有升級記錄表,建議確定手動升級,是否進行手動升級?", "Confirm Message", MessageBoxButtons.OKCancel, MessageBoxIcon.Question, MessageBoxDefaultButton.Button1) == DialogResult.OK)
                    {
                        System.Environment.Exit(0);
                    }
                    else
                    {
                        newCreateRadioUpgrade();
                        writeVerCodeToConfig(myConn);
                        MessageBox.Show("升級完成(沒有記錄表,數據庫被還原)", "提示");
                    }
                }
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }


        /// <summary> 
        /// 如果設定爲0,則無限等待</param> 
        /// 導入腳本文件
        /// 執行腳本
        /// <summary> 
        public void importSqlFile(string filePath, int seconds)
        {
            string cmdStr = "SQLCMD -U " + userName.Text + " -P " + userPwd.Text + " -S " + dataSource.Text + " -d master -i "+ filePath;
            string output = ""; //輸出字符串 
            if (filePath != null && !filePath.Equals(""))
            {
                Process process = new Process();//創建進程對象 
                ProcessStartInfo startInfo = new ProcessStartInfo();
                startInfo.FileName = "cmd.exe";//設定需要執行的命令 
                startInfo.Arguments = "/C " + cmdStr;//“/C”表示執行完命令後馬上退出 
                startInfo.UseShellExecute = false;//不使用系統外殼程序啓動 
                startInfo.RedirectStandardInput = false;//不重定向輸入 
                startInfo.RedirectStandardOutput = true; //重定向輸出 
                startInfo.CreateNoWindow = true;//不創建窗口 
                process.StartInfo = startInfo;
                try
                {
                    if (process.Start())//開始進程 
                    {
                        if (seconds == 0)
                        {
                            process.WaitForExit();//這裏無限等待進程結束 
                        }
                        else
                        {
                            process.WaitForExit(seconds); //等待進程結束,等待時間爲指定的毫秒 
                        }
                        output = process.StandardOutput.ReadToEnd();//讀取進程的輸出 
                    }
                    Console.WriteLine(output);
                }
                catch (Exception ex)
                {
                    throw ex;
                }
                finally
                {
                    if (process != null)
                    {
                        process.Close();
                    }
                }
            }
        }


        /// <summary>
        /// 獲取當前數據庫版本信息
        /// </summary>
        /// <return>當前版本號,並賦值給全局變量currentVerCode</return>
        public void getCurrentVerCode(string connectionString)
        {
            string sql = "select UPGRADE_VERSION from BEDCARD_UPGRADE_RECORD order by UPGRADE_VERSION desc";
            SqlConnection con = new SqlConnection(connectionString);
            con.Open();
            SqlCommand cmd = new SqlCommand(sql, con);
            SqlDataReader dr = cmd.ExecuteReader();
            if (dr.Read())
            {
                currentVerCode = dr["UPGRADE_VERSION"].ToString();
                string endtionname = "";
                string changlable = currentVerCode;
                char[] change;
                change = changlable.ToCharArray();
                int j = 0;
                for (int i = 0; i < changlable.Length; i++)
                {
                    if (change[i] >= '0' && change[i] <= '9')
                    {
                        endtionname += change[i];
                        j++;
                    }
                }
                if (endtionname.Length == 2)
                {
                    endtionname += '0';
                }
                currentVerCode = endtionname;


            }
            con.Close();
        }


        /// <summary>
        /// <returns>截取出的腳本中的版本號</reurns>
        /// </summary>
        /// <param name="n"></param>
        /// <returns>腳本中的版本號</reurns>
        public string getSqlFileName(int index)
        {
            string name = "";
            char[] nameindex;
            nameindex = sqlFileName[index].Substring(sqlFileName[index].LastIndexOf("\\")).ToCharArray();
            int j = 0;
            for (int i = 0; i < nameindex.Length; i++)
            {
                if (nameindex[i] >= '0' && nameindex[i] <= '9')
                {
                    name += nameindex[i];
                    j++;
                }
            }
            if (name.Length == 2)
            {
                name += '0';
            }
            return name;
        }


        /// <summary>
        /// <returns>判斷數據庫是否鏈接成功</reurns>
        /// </summary>
        /// <param name="n"></param>
        /// <returns></reurns>
        public bool checkSqlConnection()
        {
            sqlConn.ConnectionString = groupConString(dataSource.Text, "master", userName.Text, userPwd.Text);
            try
            {
                sqlConn.Open();
                return true;
            }
            catch
            {
                MessageBox.Show("鏈接失敗!", "提示!");
                return false;
            }
        }


        /// <summary>
        /// <returns>保留數據模式的升級</reurns>
        /// </summary>
        /// <param name="n"></param>
        /// <returns></reurns>
        public void saveDataRadioUpgrade()
        {
            SqlDataReader sdataReader = null;
            string getDbaseNamesSqlStr = "SELECT * FROM   master.dbo.sysdatabases where [name]='bedcardSystem'";
            SqlCommand selectDatabaseNamesCommand = new SqlCommand(getDbaseNamesSqlStr, sqlConn);
            sdataReader = selectDatabaseNamesCommand.ExecuteReader();
            if (sdataReader.Read())
            {
                MessageBox.Show("數據庫已經存在!");
                upgrade("bedcardSystem", dataSource.Text, userName.Text, userPwd.Text);
                sqlConn.Close();
            }
            else
            {
                MessageBox.Show("數據庫不存在,執行重新創建模式!");


                for (int k = 0; k < sqlFileName.Length; k++)
                {
                    importSqlFile(sqlFileName[k], 10);
                }
                sqlConn.Close();
                System.Data.SqlClient.SqlConnection myConn = new System.Data.SqlClient.SqlConnection();
                myConn.ConnectionString = groupConString(dataSource.Text, "bedcardSystem", userName.Text, userPwd.Text);
                myConn.Open();
                writeVerCodeToConfig(myConn);
                MessageBox.Show("數據庫創建成功!");
            }
        }


        /// <summary>
        /// <returns>重新創建模式的升級</reurns>
        /// </summary>
        /// <param name="n"></param>
        /// <returns></reurns>
        public void newCreateRadioUpgrade()
        {
            for (int k = 0; k < sqlFileName.Length; k++)
            {
                importSqlFile(sqlFileName[k], 100);


            }
            MessageBox.Show("重新創建升級模式完成!", "提示");
            sqlConn.Close();
        }


        /// <summary>
        /// <returns>讀取升級成功後的版本號,寫入db.congig文件</reurns>
        /// </summary>
        /// <param name="n"></param>
        /// <returns></reurns>
        public void writeVerCodeToConfig(SqlConnection scon)
        {
            string sql2 = "select UPGRADE_VERSION from BEDCARD_UPGRADE_RECORD order by UPGRADE_VERSION desc";
            string key = "VER_CODE";
            string cfgPath = "userdata\\data\\db.config";
            SqlCommand cmd = new SqlCommand(sql2, scon);
            SqlDataReader dr1 = cmd.ExecuteReader();
            if (dr1.Read())
            {
                ConfigUtil.WriteWebConfigToSetup(key, dr1["UPGRADE_VERSION"].ToString(), cfgPath);
            }
            scon.Close();
        }


        private void upgradeBottom_Click(object sender, EventArgs e)
        {


        }
    }
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章