C#連接數(shù)據(jù)庫的方法簡介
VS2005 連接ACCESS,SQL SERVER,ORACLE數(shù)據(jù)庫測試通過。
下面我們開始介紹c#連接數(shù)據(jù)庫:
首先我們新建立一個項目,填加一個類,專門用做數(shù)據(jù)庫連接用。
這里我們給這個類起名叫DataBase.cs,下面是這個類的內(nèi)容。
Web.config配置
- using System;
- using System.Data;
- using System.Configuration;
- using System.Web;
- using System.Web.Security;
- using System.Web.UI;
- using System.Web.UI.WebControls;
- using System.Web.UI.WebControls.WebParts;
- using System.Web.UI.HtmlControls;
- using System.Data.OleDb; //這一行是我們手動添加上去的
- /// < summary>
- /// DataBase 的摘要說明
- /// < /summary>
- public class DataBase
- {
- //定義一個靜態(tài)的OleDbConnection對象
- private static OleDbConnection con = null;
- //定義一個靜態(tài)的字符串
- private static string conStr = null;
- /// < summary>
- /// 得到 con 連接,默認獲取conStr
- /// < /summary>
- public static OleDbConnection Con
- {
- get
- {
- GetCon();
- return con;
- }
- }
- /// < summary>
- /// 得到 con 連接,默認獲取conStr
- /// < /summary>
- private static void GetCon()
- {
- //從Web.config文件中獲取數(shù)據(jù)庫連接字符串,Web.config文件內(nèi)容我們在后面給出
- //需要注意的是ConnectionStrings["conStr"]中的"conStr"必須
- //和Web.config中連接字符串的name保持一致,后面我們也會說到
- conStr = ConfigurationManager.ConnectionStrings["conStr"].ToString();
- //如果con對象為空則創(chuàng)建
- if (con == null)
- {
- con = new OleDbConnection(conStr);
- }
- //如果con的狀態(tài)不為打開狀態(tài),則將其Open
- if (con.State != ConnectionState.Open)
- {
- con.Open();
- }
- }
- /// < summary>
- /// 關(guān)閉數(shù)據(jù)庫連接
- /// < /summary>
- public static void Close()
- {
- //如果con不為空,判斷con的狀態(tài)是否關(guān)閉,如否,則將其關(guān)閉
- if (con != null)
- {
- if (con.State != ConnectionState.Closed)
- {
- con.Close();
- }
- con.Dispose();
- con = null;
- }
- }
- }
到這里我們的數(shù)據(jù)庫連接類基本上就寫完了,比較簡單,這里只做數(shù)據(jù)庫連接用,下面我把Web.config文件的配置內(nèi)容給大家列出來.Web.config文件的配置也非常簡單,大家只用配置一下< connectionStrings/>節(jié)點,具體將其改成這樣:
注意這里的name="conStr",這里的"conStr"必須和我們前面所說的ConnectionStrings["conStr"]保持一致,但是可以隨意定義名稱,就是說如果name="aaa",后面也必須為ConnectionStrings["aaa"]。name="aabb",后面也必須為ConnectionStrings["aabb"]。
- < connectionStrings>
- < add name="conStr" connectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=E:\newtest\ProjectCheck\DataBase\database.mdb;Persist Security Info=True"/>
- < /connectionStrings>
name說完了,我們connectionString="...",就是上面紅色的那一串就是我們數(shù)據(jù)庫的連接字符串,我這里是用的access數(shù)據(jù)庫的連接字符串,在" "中間填入你想連接的數(shù)據(jù)庫連接字符串就可以連接你想連的數(shù)據(jù)庫了。好,我們接著講,?。康鹊?,你不知道你的連接字符串怎么寫?好,那我就來教大家一個絕招。
C#連接數(shù)據(jù)庫:連接字符串
我們在桌面上點右鍵,新建一個文本文件。然后我們選中那個文件按F2,呵呵,就是改名拉,將名字改成aaa.udl。然后我們雙擊這個文件,然后點擊提供程序,看吧,出現(xiàn)了很多數(shù)據(jù)庫連接是不是?選你自己想連的數(shù)據(jù)庫。
如果你跟我一樣是連access,你就選Microsoft Jet4.0 OLE DB Provider,
如果是連sql server,就選Microsoft OLE DB Provider for SQL Server,
如果連Oracle,就選Microsoft OLE DB Provider for Oracle,
然后下一步,填入你的數(shù)據(jù)庫路徑,數(shù)據(jù)庫的登陸名和密碼,然后點測試連接,測試通過,OK,現(xiàn)在請注意,一定要把允許保存密碼的勾打上,不然等會連的時候會找不到密碼,提示你用戶名密碼出錯的,然后確定。再用記事本打開aaa.udl文件,看,連接字符串出來了,最后一行就是的,easy吧,我們把最后一行(也就是Provider開頭的那一行)復制到Web.config文件中的connectionString=""的兩個"中間,好,這就OK了~
C#連接數(shù)據(jù)庫:調(diào)用方法
因為我們使用的是靜態(tài)方法,所以我們調(diào)用的時候只需要通過類名.Con也就是 DataBase.Con 就能得到這個數(shù)據(jù)庫連接了,使用 DataBase.Close()則可關(guān)閉連接,其實可以盡量不關(guān)閉這個連接,因為我們使用的是靜態(tài)對象,所有數(shù)據(jù)庫操作都使用這個連接,不會造成服務器資源浪費,如果數(shù)據(jù)庫操作頻繁更能體現(xiàn)出這種方法的優(yōu)勢。
【編輯推薦】