ADO.NET Connection對(duì)象代表與數(shù)據(jù)源的連接。在訪問(wèn)數(shù)據(jù)庫(kù)時(shí),首先創(chuàng)建一個(gè)ADO.NET Connection對(duì)象,通過(guò)它建立到數(shù)據(jù)庫(kù)的連接。通常需要在頭文件中定義一個(gè)VConnection對(duì)象。
連接字符串
連接字符串的幾個(gè)常用參數(shù):
Provider:這個(gè)屬性用于設(shè)置或返回連接提供程序的名稱,僅用于OleDbConnection對(duì)象。
Connection Timeout或Connect Timeout:在中止嘗試并產(chǎn)生異常前,等待連接到服務(wù)器的連接時(shí)間長(zhǎng)度(以秒為單位)。默認(rèn)是15秒。
Initail Catalog:數(shù)據(jù)庫(kù)的名稱。
Data Source:連接打開(kāi)時(shí)使用的SQL Server名稱,或者是Microsoft Access數(shù)據(jù)庫(kù)的文件名。
Password:SQL Server帳戶的登錄密碼。
User ID:SQL Server登錄帳戶。
Integrated Security或Trusted Connection:此參數(shù)決定是否是安全連接。可能的值有True、False和SSPI(SSPI是True的同義詞)。
Persist Security Info:當(dāng)設(shè)置為False時(shí),如果連接是打開(kāi)的或曾經(jīng)處于打開(kāi)狀態(tài),那么安全敏感信息(如密碼)不會(huì)作為連接的一部分返回。設(shè)置屬性值為True可能有安全風(fēng)險(xiǎn)。False是默認(rèn)值。
1.寫法一
“Data Source=服務(wù)器名; Initial Catalog=數(shù)據(jù)庫(kù); User ID =用戶名; Password=密碼; Charset=UTF8; “
2.寫法二
“Server=服務(wù)器名; Database=數(shù)據(jù)庫(kù); uid=用戶名; Password=密碼;Charser=UTF8″
PS: Integrated Security = True;
如果忘了連接字符串怎么寫怎么辦?(雖然挺丟人的)
可以使用SqlConnectionStringBuilder生成字符串,如果忘了怎么寫。
MySqlConnectionStringBuilder可以用點(diǎn)出來(lái)你想要的屬性。
Connection需要釋放
Connection是實(shí)現(xiàn)了IDisposable接口的對(duì)象。使用Connection需要釋放資源。
建議用 using(Connection對(duì)象)
{
//自動(dòng)Close(); 自動(dòng)Dispose();
}
StateChange事件
這個(gè)事件會(huì)監(jiān)聽(tīng)數(shù)據(jù)庫(kù)連接狀態(tài)。當(dāng)數(shù)據(jù)庫(kù)連接狀態(tài)改變時(shí),就會(huì)觸發(fā)這個(gè)操作。
我們就可以進(jìn)行一些操作。
數(shù)據(jù)庫(kù)連接狀態(tài)是一個(gè)枚舉,ConnectionState。
目前為止ConnectionState一共有三個(gè)用的上值分別是
Closed 連接處于關(guān)閉狀態(tài)。
Connecting 連接對(duì)象正在與數(shù)據(jù)源連接。
Open 連接處于打開(kāi)狀態(tài)。
連接池
1.實(shí)驗(yàn)
首先,在連接字符串中設(shè)置 pooling = false;
然后通過(guò)
StopWatch watch =new StopWatch( );
watch.Start();
//進(jìn)行數(shù)據(jù)庫(kù)操作。
watch.Stop();
輸出watch.Elapsed;
我們驚喜的返現(xiàn),在連接字符串中設(shè)置了pooling = false以后,照原有性能下降了20~30倍。
Connection對(duì)象提供了4種連接方式
1、OLEDB :System.Data.Oledb.OledbConnection 對(duì)于非SQL Server和非Oracle數(shù)據(jù)庫(kù)使用
2、SQL:System.Data.SqlCilent.SqlConnection 用于連接SQL Server數(shù)據(jù)庫(kù)
3、ODBC:System.Data.Odbc.OdbcConnection 如果數(shù)據(jù)庫(kù)沒(méi)有內(nèi)置的OLEDB,則可以使ODBC.NET數(shù)據(jù)提供者對(duì)象。
4、Oracle:System.Data.OracleClient.OracleConnection 用于連接Oracle數(shù)據(jù)庫(kù)
為什么呢?
我繼續(xù)看,下一個(gè)實(shí)驗(yàn)。先把pooling = false刪掉。
用循環(huán)控制 Connection對(duì)象的關(guān)閉與打開(kāi)。進(jìn)行2000次吧。
然后我們使用SqlServer【工具】→【SQL Server Profiler】。使用這個(gè)工具可以觀察數(shù)據(jù)庫(kù)事務(wù)、連接記錄。
我們發(fā)現(xiàn)2000次的 Open()/Close(),在SQL Server Profiler只查看到了一次數(shù)據(jù)庫(kù)連接。
而Pooling=false以后是實(shí)實(shí)在在的連接了2000次。
做這兩個(gè)實(shí)驗(yàn)的目的是為了引出一個(gè)知識(shí)點(diǎn),即連接池。
那么,現(xiàn)象有了,我們結(jié)下來(lái)看看原理。
2.原理
原理圖
Connection對(duì)象,第一次連接建立以后,Close時(shí),并不是直接關(guān)閉,而是保存在連接池中。
下次連接時(shí),如果連接字符串相同,就調(diào)用連接池中的連接。而不是重新建立。
這樣會(huì)提高一定的效率。這一點(diǎn)在在實(shí)驗(yàn)一中驗(yàn)證過(guò)了。
//1.銷毀的是Conn對(duì)象,而連接池中的連接并沒(méi)有銷毀。
//2.連接池是ADO.NET提供的,不是數(shù)據(jù)庫(kù)的。在本地緩存中。
3.第一次運(yùn)行慢?
.NET的程序?yàn)槭裁创蠖鄶?shù)第一次運(yùn)行比較慢呢?
即時(shí)編譯固然是很重要一個(gè)原因。
進(jìn)行數(shù)據(jù)庫(kù)操作時(shí),ADO連接池是空的,也是一個(gè)原因!