1.寫法一
"Data Source=服務器名; Initial Catalog=數據庫; User ID =用戶名; PassWord=密碼; Charset=UTF8; "
2.寫法二
"Server=服務器名; Database=數據庫; uid=用戶名; Password=密碼;Charser=UTF8"
PS: Integrated Security = True;
可以使用SqlConnectionStringBuilder生成字符串,如果忘了怎么寫。
MySQLConnectionStringBuilder可以用點出來你想要的屬性。
Connection是實現了IDisposable接口的對象。使用Connection需要釋放資源。
建議用 using(Connection對象)
{
//自動Close(); 自動Dispose();
}
這個事件會監聽數據庫連接狀態。當數據庫連接狀態改變時,就會觸發這個操作。
我們就可以進行一些操作。
數據庫連接狀態是一個枚舉,ConnectionState。
目前為止ConnectionState一共有三個用的上值分別是
Closed 連接處于關閉狀態。
Connecting 連接對象正在與數據源連接。
Open 連接處于打開狀態。
1.實驗
首先,在連接字符串中設置 pooling = false;
然后通過
StopWatch watch =new StopWatch( );
watch.Start();
//進行數據庫操作。
watch.Stop();
輸出watch.Elapsed;
我們驚喜的返現,在連接字符串中設置了pooling = false以后,照原有性能下降了20~30倍。
為什么呢?
我繼續看,下一個實驗。先把pooling = false刪掉。
用循環控制 Connection對象的關閉與打開。進行2000次吧。
然后我們使用SqlServer【工具】→【SQL Server PRofiler】。使用這個工具可以觀察數據庫事務、連接記錄。
我們發現2000次的 Open()/Close(),在SQL Server Profiler只查看到了一次數據庫連接。
而Pooling=false以后是實實在在的連接了2000次。
做這兩個實驗的目的是為了引出一個知識點,即連接池。
那么,現象有了,我們結下來看看原理。
2.原理
原理圖
Connection對象,第一次連接建立以后,Close時,并不是直接關閉,而是保存在連接池中。
下次連接時,如果連接字符串相同,就調用連接池中的連接。而不是重新建立。
這樣會提高一定的效率。這一點在在實驗一中驗證過了。
//1.銷毀的是Conn對象,而連接池中的連接并沒有銷毀。
//2.連接池是ADO.NET提供的,不是數據庫的。在本地緩存中。
3.第一次運行慢?
.NET的程序為什么大多數第一次運行比較慢呢?
即時編譯固然是很重要一個原因。
進行數據庫操作時,ADO連接池是空的,也是一個原因!
新聞熱點
疑難解答