C#創(chuàng)建數(shù)據(jù)庫及附加數(shù)據(jù)庫的操作方法
本文實例講述了C#創(chuàng)建數(shù)據(jù)庫及附加數(shù)據(jù)庫的操作方法。分享給大家供大家參考,具體如下:
/// <summary> /// 附加數(shù)據(jù)庫方法 /// </summary> /// <param name="strSql">連接數(shù)據(jù)庫字符串,連接master系統(tǒng)數(shù)據(jù)庫</param> /// <param name="DataName">數(shù)據(jù)庫名字</param> /// <param name="strMdf">數(shù)據(jù)庫文件MDF的路徑</param> /// <param name="strLdf">數(shù)據(jù)庫文件LDF的路徑</param> /// <param name="path">安裝目錄</param> private void CreateDataBase( string strSql, string DataName, string strMdf, string strLdf, string path) { SqlConnection myConn = new SqlConnection(strSql); String str = null ; try { str = " EXEC sp_attach_db @dbname='"+DataName+"',@filename1='"+strMdf+"',@filename2='"+strLdf+"'"; SqlCommand myCommand = new SqlCommand(str, myConn); myConn.Open(); myCommand.ExecuteNonQuery(); MessageBox.Show("數(shù)據(jù)庫安裝成功!點擊確定繼續(xù)");//需Using System.Windows.Forms } catch(Exception e) { MessageBox.Show("數(shù)據(jù)庫安裝失?。? + e.Message+"\n\n"+"您可以手動附加數(shù)據(jù)"); System.Diagnostics.Process.Start(path);//打開安裝目錄 } finally { myConn.Close(); } } public override void Install(System.Collections.IDictionary stateSaver) { string server = this.Context.Parameters["server"];//服務(wù)器名稱 string uid = this.Context.Parameters["user"];//SQlServer用戶名 string pwd = this.Context.Parameters["pwd"];//密碼 string path = this.Context.Parameters["targetdir"];//安裝目錄 string strSql = "server=" + server + ";uid=" + uid + ";pwd=" + pwd + ";database=master";//連接數(shù)據(jù)庫字符串 string DataName = "JXC";//數(shù)據(jù)庫名 string strMdf = path + @"JXC.mdf";//MDF文件路徑,這里需注意文件名要與剛添加的數(shù)據(jù)庫文件名一樣! string strLdf = path + @"jxc_log.ldf";//LDF文件路徑 base.Install(stateSaver); this.CreateDataBase(strSql, DataName, strMdf, strLdf, path);//開始創(chuàng)建數(shù)據(jù)庫 } /// <summary> /// 測試連接 /// </summary> /// <param name="serverName"></param> /// <param name="dbName"></param> /// <param name="userName"></param> /// <param name="password"></param> private SqlConnection TestConnection(string serverName, string dbName, string userName, string password) { string connectionString = GetConnectionString(serverName, dbName, userName, password); SqlConnection connection = new SqlConnection(connectionString); try { if (connection.State != ConnectionState.Open) { connection.Open(); } return connection; } catch { CloseConnection(connection); throw new InstallException("安裝失敗!\n數(shù)據(jù)庫配置有誤,請正確配置信息!"); } } /// <summary> /// 得到連接字符串 /// </summary> /// <param name="serverName"></param> /// <param name="dbName"></param> /// <param name="userName"></param> /// <param name="password"></param> /// <returns></returns> private string GetConnectionString(string serverName, string dbName, string userName, string password) { string connectionString = "Data Source={0};Initial Catalog={1};User ID={2};Password={3}"; connectionString = string.Format(connectionString, serverName, dbName, userName, password); return connectionString; } /// <summary> /// 創(chuàng)建數(shù)據(jù)庫 /// </summary> /// <param name="serverName"></param> /// <param name="dbName"></param> /// <param name="userName"></param> /// <param name="password"></param> /// <param name="connection"></param> /// <param name="stateSaver"></param> public int CreateDataBase(SqlConnection connection) { int result = -1; connection.ChangeDatabase("master"); string createDBSql = @" if Exists(select 1 from sysdatabases where [name]=N'{0}') begin drop database {0} end GO CREATE DATABASE {0} "; createDBSql = string.Format(createDBSql, _dbName); //因為有Go在SQLCommand中不認(rèn)識,所以以Go為分隔符取sql語句 char[] split = new char[] { 'G', 'O' }; string[] sqlList = createDBSql.Split(split); SqlCommand command = null; try { command = connection.CreateCommand(); command.CommandType = System.Data.CommandType.Text; foreach (string sqlItem in sqlList) { if (sqlItem.Length > 2) { command.CommandText = sqlItem; result = command.ExecuteNonQuery(); } } return result; } catch { CloseConnection(connection); command.Dispose(); throw new InstallException("安裝失敗!\n數(shù)據(jù)庫配置不正確!"); } } /// <summary> /// 分隔SQL語句 /// </summary> /// <param name="sql"></param> /// <returns></returns> private string[] splitSql(string sql) { Regex regex = new Regex("^GO", RegexOptions.IgnoreCase | RegexOptions.Multiline); string[] sqlList = regex.Split(sql.ToUpper()); return sqlList; }
更多關(guān)于C#相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《C#程序設(shè)計之線程使用技巧總結(jié)》、《C#操作Excel技巧總結(jié)》、《C#中XML文件操作技巧匯總》、《C#常見控件用法教程》、《WinForm控件用法總結(jié)》、《C#數(shù)據(jù)結(jié)構(gòu)與算法教程》、《C#數(shù)組操作技巧總結(jié)》及《C#面向?qū)ο蟪绦蛟O(shè)計入門教程》
希望本文所述對大家C#程序設(shè)計有所幫助。
上一篇:C#控制Excel Sheet使其自適應(yīng)頁寬與列寬的方法
欄 目:C#教程
本文標(biāo)題:C#創(chuàng)建數(shù)據(jù)庫及附加數(shù)據(jù)庫的操作方法
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/6417.html
您可能感興趣的文章
- 01-10winform實現(xiàn)創(chuàng)建最前端窗體的方法
- 01-10C#實現(xiàn)主窗體最小化后出現(xiàn)懸浮框及雙擊懸浮框恢復(fù)原窗體的方
- 01-10C#動態(tài)創(chuàng)建button的方法
- 01-10深入淺出23種設(shè)計模式
- 01-10winform創(chuàng)建不規(guī)則窗體的方法
- 01-10C#動態(tài)創(chuàng)建Access數(shù)據(jù)庫及密碼的方法
- 01-10C#實現(xiàn)在啟動目錄創(chuàng)建快捷方式的方法
- 01-10C#使用ADO.Net部件來訪問Access數(shù)據(jù)庫的方法
- 01-10C#路徑,文件,目錄及IO常見操作匯總
- 01-10C#禁止textbox復(fù)制、粘貼、剪切及鼠標(biāo)右鍵的方法


閱讀排行
本欄相關(guān)
- 01-10C#通過反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實現(xiàn)txt定位指定行完整實例
- 01-10WinForm實現(xiàn)仿視頻 器左下角滾動新
- 01-10C#停止線程的方法
- 01-10C#實現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實現(xiàn)讀取注冊表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機閱讀
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10C#中split用法實例總結(jié)
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10delphi制作wav文件的方法
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05織夢dedecms什么時候用欄目交叉功能?