日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

ADO.NET中的Connection對象詳解_.Net教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:Asp.net配合easyui實(shí)現(xiàn)返回json數(shù)據(jù)實(shí)例
最近想用asp.net配合easyui開發(fā)一個(gè)小框架,然后再用到easyui的combobox的時(shí)候出現(xiàn)了一個(gè)問題,總所周知,easyui的文檔上給出的combobox的格式是 代碼如下:input class=easyui-combobox name=language data-options= url:'../combobox/combobox_data1.json', valueFiel

   連接字符串

  連接字符串的幾個(gè)常用參數(shù):

  Provider:這個(gè)屬性用于設(shè)置或返回連接提供程序的名稱,僅用于OleDbConnection對象。

  Connection Timeout或Connect Timeout:在中止嘗試并產(chǎn)生異常前,等待連接到服務(wù)器的連接時(shí)間長度(以秒為單位)。默認(rèn)是15秒。

  Initail Catalog:數(shù)據(jù)庫的名稱。

  Data Source:連接打開時(shí)使用的sql server名稱,或者是Microsoft Access數(shù)據(jù)庫的文件名。

  Password:SQL Server帳戶的登錄密碼。

  User ID:SQL Server登錄帳戶。

  Integrated Security或Trusted Connection:此參數(shù)決定是否是安全連接�?赡艿闹涤蠺rue、False和SSPI(SSPI是True的同義詞)。

  Persist Security Info:當(dāng)設(shè)置為False時(shí),如果連接是打開的或曾經(jīng)處于打開狀態(tài),那么安全敏感信息(如密碼)不會作為連接的一部分返回。設(shè)置屬性值為True可能有安全風(fēng)險(xiǎn)。False是默認(rèn)值。

  1.寫法一

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

  2.寫法二

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

  PS: Integrated Security = True;

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

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

  MySqlConnectionStringBuilder可以用點(diǎn)出來你想要的屬性。

  Connection需要釋放

  Connection是實(shí)現(xiàn)了IDisposable接口的對象。使用Connection需要釋放資源。

  建議用 using(Connection對象)

  {

  //自動Close(); 自動Dispose();

  }

  StateChange事件

  這個(gè)事件會監(jiān)聽數(shù)據(jù)庫連接狀態(tài)。當(dāng)數(shù)據(jù)庫連接狀態(tài)改變時(shí),就會觸發(fā)這個(gè)操作。

  我們就可以進(jìn)行一些操作。

  數(shù)據(jù)庫連接狀態(tài)是一個(gè)枚舉,ConnectionState。

  目前為止ConnectionState一共有三個(gè)用的上值分別是

  Closed 連接處于關(guān)閉狀態(tài)。

  Connecting 連接對象正在與數(shù)據(jù)源連接。

  Open 連接處于打開狀態(tài)。

  連接池

  1.實(shí)驗(yàn)

  首先,在連接字符串中設(shè)置 pooling = false;

  然后通過

  StopWatch watch =new StopWatch( );

  watch.Start();

  //進(jìn)行數(shù)據(jù)庫操作。

  watch.Stop();

  輸出watch.Elapsed;

  我們驚喜的返現(xiàn),在連接字符串中設(shè)置了pooling = false以后,照原有性能下降了20~30倍。

  Connection對象提供了4種連接方式

  1、OLEDB :System.Data.Oledb.OledbConnection 對于非SQL Server和非Oracle數(shù)據(jù)庫使用

  2、SQL:System.Data.SqlCilent.SqlConnection 用于連接SQL Server數(shù)據(jù)庫

  3、ODBC:System.Data.Odbc.OdbcConnection 如果數(shù)據(jù)庫沒有內(nèi)置的OLEDB,則可以使ODBC.NET數(shù)據(jù)提供者對象。

  4、Oracle:System.Data.OracleClient.OracleConnection 用于連接Oracle數(shù)據(jù)庫

  為什么呢?

  我繼續(xù)看,下一個(gè)實(shí)驗(yàn)。先把pooling = false刪掉。

  用循環(huán)控制 Connection對象的關(guān)閉與打開。進(jìn)行2000次吧。

  然后我們使用SqlServer【工具】→【SQL Server Profiler】。使用這個(gè)工具可以觀察數(shù)據(jù)庫事務(wù)、連接記錄。

  我們發(fā)現(xiàn)2000次的 Open()/Close(),在SQL Server Profiler只查看到了一次數(shù)據(jù)庫連接。

  而Pooling=false以后是實(shí)實(shí)在在的連接了2000次。

  做這兩個(gè)實(shí)驗(yàn)的目的是為了引出一個(gè)知識點(diǎn),即連接池。

  那么,現(xiàn)象有了,我們結(jié)下來看看原理。

  2.原理

  原理圖

ADO.NET中的Connection對象詳解 模板無憂

  Connection對象,第一次連接建立以后,Close時(shí),并不是直接關(guān)閉,而是保存在連接池中。

  下次連接時(shí),如果連接字符串相同,就調(diào)用連接池中的連接。而不是重新建立。

  這樣會提高一定的效率。這一點(diǎn)在在實(shí)驗(yàn)一中驗(yàn)證過了。

  //1.銷毀的是Conn對象,而連接池中的連接并沒有銷毀。

  //2.連接池是ADO.NET提供的,不是數(shù)據(jù)庫的。在本地緩存中。

  3.第一次運(yùn)行慢?

  .NET的程序?yàn)槭裁创蠖鄶?shù)第一次運(yùn)行比較慢呢?

  即時(shí)編譯固然是很重要一個(gè)原因。

  進(jìn)行數(shù)據(jù)庫操作時(shí),ADO連接池是空的,也是一個(gè)原因!

分享:ASP.NET中實(shí)現(xiàn)獲取調(diào)用方法名
需要添加相應(yīng)的命名空間: 復(fù)制代碼 代碼如下: using System; using System.Diagnostics; using System.Reflection; 如果僅是獲取當(dāng)前方法名,可以使用如下代碼: 復(fù)制代碼 代碼如下: public static void WriteSysLog(int level, string content) { MethodBase mb = Me

來源:模板無憂//所屬分類:.Net教程/更新時(shí)間:2015-01-22
相關(guān).Net教程