贛縣網(wǎng)站建設(shè)國內(nèi)新聞最新消息十條
?.NET開源 ORM 框架 SqlSugar 系列
- 【開篇】.NET開源 ORM 框架 SqlSugar 系列
- 【入門必看】.NET開源 ORM 框架 SqlSugar 系列
- 【實(shí)體配置】.NET開源 ORM 框架 SqlSugar 系列
- 【Db First】.NET開源 ORM 框架 SqlSugar 系列
- 【Code First】.NET開源 ORM 框架 SqlSugar 系列
- 【數(shù)據(jù)事務(wù)】.NET開源 ORM 框架 SqlSugar 系列
- 【連接池】.NET開源 ORM 框架 SqlSugar 系列-CSDN博客
1. ADO.NET?連接池
如何啟用和禁用連接池?
連接字符串中將連接池值 Pooling 設(shè)置為 true 或 yes,則會啟用連接池(默認(rèn)啟用)。
啟用后連接池后系統(tǒng)會根據(jù)并發(fā)情況將連接池保持在一個合理區(qū)間,讓性能最大化,并不會立馬清空。而是將他狀態(tài)更改為sleep。禁用連接池性能會差一些,open就打開連接池 close就關(guān)閉連接池。
1.1 Open()?
1、啟用連接池情況(默認(rèn))
先找有沒有睡眠的連接池有恢復(fù)連接池,如果沒有睡眠的連接池打開新的連接池
2、禁用連接池情況(需要字符串關(guān)閉)
打開新連接池
1.2 Close ()
1、啟用連接池情況(默認(rèn))
將現(xiàn)有連接池睡眠
2、禁用連接池情況(需要字符串關(guān)閉)
關(guān)閉連接池
1.3 dispose()
方法實(shí)際是和 close()做的同一件事,唯一區(qū)別是 dispose?會銷毀當(dāng)前C#對象
SqlSugar dispose后在打開不會報(bào)錯,原理如下:
var db = GetInstance();db.Open();Console.WriteLine(db.Ado.Connection.GetHashCode());db.Close();Console.WriteLine(db.Ado.Connection.GetHashCode());db.Dispose();//如果下次在使用db會new出新的SqlConnection和Ado.net不一樣Ado.net是直接報(bào)錯Console.WriteLine(db.Ado.Connection.GetHashCode());
輸出結(jié)果如下:
唯一的區(qū)別是Dispose后在使用db,db對象會換成新的而不在是以前的,而close后在使用還是同一個db對象。
2、SqlConnection和連接池
SqlConnection?非線程安全對象,不同上下文要new不同對象
con.Open(); //請求數(shù)據(jù)庫連接池 查找有沒有 sleep 狀態(tài)的,沒有創(chuàng)建連接池
con.Close();//將當(dāng)前連接池狀態(tài)改為sleep , 如果長時間不用會銷毀
上面的原理可以看出
1. 同一個對象多次 open?和 close?都是在現(xiàn)有的連接池里面去操作
2. 就算是多個SqlConnection不在同時間請求,也可能會用同一個連接池?
3.多個SqlConnection?并發(fā)操作會找有沒有空閑的連接池,沒有在創(chuàng)建
所以連接池在.NET中?微軟封裝的很好,很成熟?多數(shù).NET用戶都不知道是什么玩意兒。
連接超時設(shè)置
在連接池符串加上 Connection Timeout=10 ,默認(rèn)是30秒,單位秒
.NET中要配置連接池嗎?
?答:什么都不用配置只要學(xué)會 open 和 close就行了?
3、SqlSugarClient原理
1.手動釋放模式和SqlConnection原理一模一樣,底層就是用的SqlConnection并且需要注意線程安全
//創(chuàng)建數(shù)據(jù)庫對象 SqlSugarClient SqlSugarClient db = new SqlSugarClient(new ConnectionConfig(){ConnectionString = "Server=.xxxxx", DbType = DbType.SqlServer,IsAutoCloseConnection = false//手動釋放 是長連接 });//需要手動using //或者//db.Open();//db.Close();
2.自動釋放(推薦),說白了不需要你去寫?using 或者 close和open
//創(chuàng)建數(shù)據(jù)庫對象 SqlSugarClient SqlSugarClient db = new SqlSugarClient(new ConnectionConfig(){ConnectionString = "Server=.xxxxx", DbType = DbType.SqlServer,IsAutoCloseConnection = true//自動釋放});//寫代碼就不需要考慮 open close 直接用就行了
?情況1: 沒有事務(wù)的情況 ,每次操作自動調(diào)用 open和close
?情況2:?有事務(wù)的情況下 ,開啟事務(wù)調(diào)用 open? 提交或者回滾事務(wù)調(diào)用 close
4、SqlSugarScope原理
它是對 SqlSugarClient 的封裝讓他支持線程安全,并且在不同上下文自動new?出?SqlSugarClient,在編寫代碼的時候不需要考慮他線程是否安全
什么是上下文?
異步情況:?在同一串a(chǎn)wait?中是一個上下文
同步情況:?在同一個線程是同一個上下文
同一個SqlSugarScope?做到了在同一個上下文共享一個對象,不同上下文自動去NEW
5、如何驗(yàn)證是否釋放
默認(rèn)情況下只要超過100個請求沒關(guān)閉就會報(bào)錯,不同庫可能有差異
for (int i = 0; i < 501; i++){SqlSugarClient db = new SqlSugarClient(new ConnectionConfig(){DbType = DbType.Oracle,ConnectionString = Config.ConnectionString,IsAutoCloseConnection = false//設(shè)成關(guān)閉這個代碼會直接報(bào)錯});db.Ado.GetInt("SELECT 1 from dual"); }//IsAutoCloseConnection=true 執(zhí)行成功//IsAutoCloseConnection=false 會出現(xiàn)連接池超時或者超過上限等錯誤
6、總結(jié)
他們3者的關(guān)系應(yīng)該是這樣的:
- SqlSugarScope?底層+自動釋放+上下文安全
- SqlSugarClient? 底層+自動釋放控制
- SqlConnection? ?底層