国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

ADO.NET中的Connection詳解

2019-11-14 16:15:22
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

連接字符串

1.寫(xiě)法一

"Data Source=服務(wù)器名; Initial Catalog=數(shù)據(jù)庫(kù); User ID =用戶名; PassWord=密碼; Charset=UTF8; "

2.寫(xiě)法二

"Server=服務(wù)器名; Database=數(shù)據(jù)庫(kù); uid=用戶名; Password=密碼;Charser=UTF8"

PS:   Integrated Security = True;

如果忘了連接字符串怎么寫(xiě)怎么辦?(雖然挺丟人的)

可以使用SqlConnectionStringBuilder生成字符串,如果忘了怎么寫(xiě)。

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倍。

為什么呢?

 

我繼續(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.原理

原理圖

clipboard

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è)原因!


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 余庆县| 松阳县| 长乐市| 内乡县| 禄丰县| 宝应县| 达州市| 含山县| 吉首市| 西藏| 扶沟县| 花莲县| 新干县| 固原市| 屏边| 红河县| 屏山县| 无棣县| 莱芜市| 定远县| 玛沁县| 永善县| 沈阳市| 横山县| 兴业县| 时尚| 洛宁县| 凤山市| 鲜城| 怀仁县| 静海县| 永泰县| 诸暨市| 长子县| 华阴市| 广德县| 河源市| 麻江县| 揭西县| 丽水市| 大新县|