中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

.Net連接數據庫的方式是什么

發布時間:2022-05-05 10:06:20 來源:億速云 閱讀:140 作者:zzz 欄目:開發技術

這篇文章主要講解了“.Net連接數據庫的方式是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“.Net連接數據庫的方式是什么”吧!

一、C#中連接字符串常用內容

參數說明
Provider設置或者返回提供的連接程式的名稱,僅用于OLeDbConnection對象
Connection Timeout在終止嘗試并產生異常前,等待連接到服務器的連接時間長度(以秒為單位)。默認值是15秒
Initial Catalog或Database連接的數據庫名稱
Data Source或Server連接打開時使用的SQL Server服務簽名,或者Access數據庫文件名(localhost或127.0.0.1)
Password或pwdSql Server登錄密碼
User ID或uidSql Server登錄賬戶
Integrated Sercuity決定連接是否是安全連接,可能的值有True,False和SSPI(SSPI和True是同義詞)

以上的參數是不分大小寫的,例如uid,UID,Uid都表示連接的數據庫用戶

Integrated Security參數用于本地windows驗證登錄時,其值應該設置為True,例如("server=localhost;database=mydb;Integrated security=true")

二、.net 數據庫連接池超時問題

(1)數據庫Connection Pool 連接池是什么

每當程序需要讀寫數據庫的時候。Connection.Open()會使用ConnectionString連接到數據庫,數據庫會為程序建立 一個連接,并且保持打開狀態,此后程序就可以使用T-SQL語句來查詢/更新數據庫。當執行到Connection.Close()后,數據庫就會關閉當 前的連接。

但是如果我的程序需要不定時的打開和關閉連接,(比如說 ASP.Net 或是 Web Service ),例如當Http Request發送到服務器的時候、,我們需要打開Connection 然后使用Select* from Table 返回一個DataTable/DataSet給客戶端/瀏覽器,然后關閉當前的Connection。那每次都Open/Close Connection 如此的頻繁操作對于整個系統無疑就成了一種浪費。

ADO.Net Team就給出了一個比較好地解決方法。將先前的Connection保存起來,當下一次需要打開連接的時候就將先前的Connection 交給下一個連接。這就是Connection Pool。

(2)數據庫Connection Pool連接池的運行方式

  • 1、當一個程序執行Connection.open()時候,ADO.net就需要判斷,此連接是否支持Connection Pool (Pooling 默認為True)

(1)、如果指定為False, ADO.net就與數據庫之間創建一個連接,然后返回給程序。

(2)、如果指定為 True,ADO.net就會根據ConnectString創建一個Connection Pool,然后向Connection Pool中填充Connection。填充多少個Connection由Min Pool Size (默認為0)屬性來決定。例如如果指定為5,則ADO.net會一次與SQL數據庫之間打開5個連接,然后將4個Connection,保存在 Connection Pool中,1個Connection返回給程序。

  • 2、當程序執行到Connection.close() 的時候。如果Pooling 為True,ADO.net 就把當前的Connection放到Connection Pool并且保持與數據庫之間的連接。

同時還會判斷Connection Lifetime(默認為0)屬性,0代表無限大,如果Connection存在的時間超過了Connection LifeTime,ADO.net就會關閉的Connection同時斷開與數據庫的連接,而不是重新保存到Connection Pool中。

  • 3、當下一次Connection.Open() 執行的時候,ADO.Net就會判斷新的ConnectionString與之前保存在Connection Pool中的Connection的connectionString是否一致。

  • 4、 ADO.net需要判斷當前的Connection Pool中是否有可以使用的Connection(沒有被其他程序所占用),如果沒有的話,ADO.net就需要判斷ConnectionString設 置的Max Pool Size (默認為100)

(1)、如果Connection Pool中的所有Connection沒有達到Max Pool Size,ADO.net則會再次連接數據庫,創建一個連接,然后將Connection返回給程序。

(2)、如果已經達到了 MaxPoolSize,ADO.net就不會再次創建任何新的連接,而是等待Connection Pool中被其他程序所占用的Connection釋放,這個等待時間受SqlConnection.ConnectionTimeout(默認是15 秒)限制,也就是說如果時間超過了15秒,SqlConnection就會拋出超時錯誤。

  • 5、如果有可用的Connection,從Connection Pool 取出的Connection也不是直接就返回給程序,ADO.net還需要檢查ConnectionString的ConnectionReset屬性 (默認為True)是否需要對Connection 最一次reset。

(3)ASP.NET程序對max pool size的配置

在連接字符串中添加如下內容:

pooling=true;min pool size=5;max pool size=512;

其中Max Pool Size如果未設置則默認為100,理論最大值為32767。最大連接數是連接池能申請的最大連接數,如果數據庫連接請求超過此數,后面的數據庫連接請求將被加入到等待隊列中,這會影響之后的數據庫操作。在等待隊列中,默認等待與服務器的連接的時間為15秒。

默認連接池大小一般是100。

(4)查看應用程序池占用數量

select * from sysprocesses where dbid= db_id('數據庫名')

查詢出來有幾條數據就證明有幾個連接數量。

感謝各位的閱讀,以上就是“.Net連接數據庫的方式是什么”的內容了,經過本文的學習后,相信大家對.Net連接數據庫的方式是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

淮安市| 五峰| 西青区| 木兰县| 星子县| 金沙县| 屯留县| 吕梁市| 石嘴山市| 双柏县| 墨脱县| 友谊县| 六枝特区| 邵东县| 永泰县| 绥江县| 孟津县| 靖西县| 澜沧| 山西省| 阜阳市| 晋中市| 湟中县| 广安市| 山东省| 名山县| 南丹县| 宜州市| 镇赉县| 天镇县| 夏河县| 鹤山市| 郑州市| 庄河市| 马关县| 南平市| 达尔| 淳安县| 肃北| 通化县| 合江县|