C#中通過(guò)使用Connection類(lèi)來(lái)實(shí)現(xiàn)打開(kāi)/關(guān)閉數(shù)據(jù)庫(kù)的代碼實(shí)例
為了訪(fǎng)問(wèn)數(shù)據(jù)庫(kù),就要提供數(shù)據(jù)庫(kù)連接類(lèi),在C#中,是通過(guò)Connection類(lèi)來(lái)實(shí)現(xiàn)的
四種類(lèi)型的連接方式
- SQLConnection
- ADOConnection
- OractleConnection
- ODBCConnection
以SQLConnection方式實(shí)現(xiàn)數(shù)據(jù)庫(kù)的連接:
- SQL Server數(shù)據(jù)庫(kù)
- windows 身份信息驗(yàn)證
步驟:
- 引用命名空間 using System.Data.SqlClient;
- 將連接方法聲明值字符串中
- 創(chuàng)建Connection對(duì)象
- 調(diào)用方法
為了節(jié)省系統(tǒng)資源提高系統(tǒng)性能,最好使用完數(shù)據(jù)庫(kù)就關(guān)閉連接,在C#語(yǔ)言中由于GC(垃圾回收機(jī)制)的存在,會(huì)在以后的某個(gè)時(shí)刻釋放資源,它是非決定性的,并不能確定這個(gè)過(guò)程在什么時(shí)候發(fā)生,當(dāng)忘記關(guān)閉數(shù)據(jù)庫(kù)是可以u(píng)sing語(yǔ)句確保對(duì)象退出時(shí)立即被釋放,從而達(dá)到關(guān)閉數(shù)據(jù)庫(kù)的作用,還有一種通過(guò)try..catch..final..
語(yǔ)句控制連接數(shù)據(jù)庫(kù)的關(guān)閉來(lái)提高性能
代碼實(shí)現(xiàn)如下:
using System; using System.Data.SqlClient; //引入命名空間 namespace Csharpone { class Program { static void Main(string[] args) { //windows 身份信息驗(yàn)證 下面的csharp01為新建的數(shù)據(jù)庫(kù)名稱(chēng) string constr = "Server.;integrated security=SSPI;Initial Catalog=csharp01"; SqlConnection mysqlCon = new SqlConnection(constr); //實(shí)例化 mysqlCon.Open(); //打開(kāi)數(shù)據(jù)庫(kù) Console.WriteLine("數(shù)據(jù)庫(kù)打開(kāi)"); //正常打印說(shuō)明沒(méi)問(wèn)題,否則會(huì)拋出異常 //SQ驗(yàn)證方式 name是你設(shè)置的數(shù)據(jù)庫(kù)的用戶(hù)名,pwd是密碼 csharp02是數(shù)據(jù)庫(kù)名稱(chēng) string constr1 = "Server.;user=name; pwd=mima; database=csharp02"; SqlConnection mysqlCon1 = new SqlConnection(constr1); //實(shí)例化 mysqlCon1.Open(); //打開(kāi)數(shù)據(jù)庫(kù) Console.WriteLine("SQL方式 數(shù)據(jù)庫(kù)打開(kāi)"); /*通過(guò)using語(yǔ)句實(shí)現(xiàn)數(shù)據(jù)庫(kù)的關(guān)閉 using (mysqlCon1) { mysqlCon1.Open(); Console.WriteLine("數(shù)據(jù)成功打開(kāi)"); //執(zhí)行完立即關(guān)閉 } //通過(guò)try..catch..finally.. try { mysqlCon.Open(); Console.WriteLine("數(shù)據(jù)庫(kù)關(guān)閉"); } catch { } finally { mysqlCon.Close(); Console.WriteLine("關(guān)閉數(shù)據(jù)庫(kù)"); }*/ //以上兩種方式結(jié)合使用,確保數(shù)據(jù)庫(kù)占用資源得到釋放 try { using (mysqlCon) { mysqlCon.Open(); Console.WriteLine("打開(kāi)數(shù)據(jù)庫(kù)"); } } catch { } finally { mysqlCon.Close(); Console.WriteLine("關(guān)閉數(shù)據(jù)庫(kù)"); } Console.Read(); } } }
MySQL數(shù)據(jù)庫(kù)代碼如下:
using System; using MySql.Data.MySqlClient; //導(dǎo)入引用,并且添加命名空間 namespace CSharp連接Mysql { class Program { static void Main(string[] args) { string connectStr = "server=localhost;port=3306;database=czhenya01;user=root;password=123456;"; //并沒(méi)有建立數(shù)據(jù)庫(kù)連接 MySqlConnection conn = new MySqlConnection(connectStr); try { conn.Open(); //建立連接,打開(kāi)數(shù)據(jù)庫(kù) Console.WriteLine("打開(kāi)數(shù)據(jù)庫(kù)成功"); }catch (Exception ex) { Console.WriteLine(ex.ToString()); } finally { conn.Close(); //關(guān)閉連接 } Console.ReadKey(); } } }
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)我們的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
欄 目:C#教程
本文標(biāo)題:C#中通過(guò)使用Connection類(lèi)來(lái)實(shí)現(xiàn)打開(kāi)/關(guān)閉數(shù)據(jù)庫(kù)的代碼實(shí)例
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5031.html
您可能感興趣的文章
- 01-10C#通過(guò)反射獲取當(dāng)前工程中所有窗體并打開(kāi)的方法
- 01-10C#通過(guò)重寫(xiě)Panel改變邊框顏色與寬度的方法
- 01-10C#實(shí)現(xiàn)Winform中打開(kāi)網(wǎng)頁(yè)頁(yè)面的方法
- 01-10C#實(shí)現(xiàn)由四周向中心縮小的窗體退出特效
- 01-10Extjs4如何處理后臺(tái)json數(shù)據(jù)中日期和時(shí)間
- 01-10C#通過(guò)Semaphore類(lèi)控制線(xiàn)程隊(duì)列的方法
- 01-10C#使用Dispose模式實(shí)現(xiàn)手動(dòng)對(duì)資源的釋放
- 01-10C#3.0使用EventLog類(lèi)寫(xiě)Windows事件日志的方法
- 01-10C#中DataGridView常用操作實(shí)例小結(jié)
- 01-10C#編程獲取資源文件中圖片的方法


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10C#通過(guò)反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁(yè)無(wú)法打開(kāi)的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新
- 01-10C#停止線(xiàn)程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過(guò)重寫(xiě)Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 01-10delphi制作wav文件的方法
- 01-10C#中split用法實(shí)例總結(jié)
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery