亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

要關閉數據庫連接的原因解析

2020-02-24 14:32:10
字體:
來源:轉載
供稿:網友

? ? ? ?相信很多人都會好奇會為什么一定要關閉數據庫連接呢?我們可不可以不關閉數據庫連接?現在小編為你分享要關閉數據庫連接的原因解析吧。

? ? ? ?首先要說明的是連接數是有限制的:

代碼如下:

?

for (int i = 0; i < 10000; i++)
{
??? SqlConnection conn = new SqlConnection(@"Data Source=./SQLEXPRESS;
??????????????? AttachDbFilename=""E:/DB/NORTHWND.mdf"";
??????????????? Integrated Security=True;Connect Timeout=30;User Instance=True");

?

??? conn.Open();
??? Console.WriteLine("打開了{0}個連接", i);
}


運行結果如下:

image

? ? ? ?過一會就會提示打開連接超時了:

? ? ? ?可以看到數據庫連接時有限制的,如果連接不關閉,而且使用的人比較多,那么系統很快就down掉了。

? ? ? ?但是有時候由于某些原因應用程序可能只是幾個人使用,所以就有人設計了:

? ? ? ?在應用程序啟動的時候打開數據庫連接,在應用程序關閉的時候關閉數據庫連接

? ? ? ?那么使用這種方式有什么問題呢?

? ? ? ?首先假設有一張表Nums,表定義如下:

? ? ? ?Main代碼如下:

?

SqlConnection conn = new SqlConnection(@"Data Source=./SQLEXPRESS;
??????????????????? AttachDbFilename=""E:/DB/NORTHWND.mdf"";
??????????????????? Integrated Security=True;Connect Timeout=30;User Instance=True");
conn.Open();
Parallel.For(1, 9999, (id) =>
{
??? ExecuteCommand(conn, id);
});


? ? ? ?就是從1到9999開始執行ExecuteCommand

?

ExecuteCommand代碼如下:

?

private static void ExecuteCommand(SqlConnection conn, int id)
{
??? Console.WriteLine("正在執行." + id);

?

??? Thread.Sleep(100);

??? SqlCommand cmd = new SqlCommand(
?????? string.Format("Insert into Nums values('{0}') ", id), conn);

??? cmd.ExecuteNonQuery();
}


? ? ? ?運行:

? ? ? ?可以看到ExecuteNonQuery方法拋出了異常,原因是連接處于關閉狀態。

? ? ? ?可是我們的連接一直都是open著的啊,并沒有調用close,dispose之類的方法啊。

? ? ? ?于是在ExecuteCommand前面增加判斷條件:

if (conn.State != System.Data.ConnectionState.Open)
??? conn.Open();再次運行:

? ? ? ?可以看到還是會出現連接已關閉的問題。你知道什么原因嗎?

? ? ? ?這里是由于多線程環境引起的。所以需要加鎖。

?

private static object syncObj = new object();
private static void ExecuteCommand(SqlConnection conn, int id)
{
??? lock (syncObj)
??? {
??????? if (conn.State != System.Data.ConnectionState.Open)
??????????? conn.Open();
??????? Console.WriteLine("正在執行.." + id);
??????? Thread.Sleep(100);
??????? SqlCommand cmd = new SqlCommand(
?????????? string.Format("Insert into Nums values('{0}') ", id), conn);
??????? cmd.ExecuteNonQuery();
??? }
}


? ? ? ?再次運行:可以發現基本沒問題了.

? ? ? ?修改Parallel.For的最大值上限,要測試下是否可以長期執行了。


Parallel.For(1, Int32.MaxValue, (id) =>
??????????? {
??????????????? ExecuteCommand(conn, id);
??????????? });

一天測試下來,沒出現任何問題。

結論:對于某些只有幾個人使用的應用程序,可以不關閉數據庫連接,但是在寫代碼的時候最好要加上連接是否打開的判斷。

? ? ? ?上文是關于要關閉數據庫連接的原因解析,相信大家都有了一定的了解,想要了解更多的技術信息,請繼續關注武林技術頻道吧!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美亚洲视频在线观看| 国产精品xxxxx| 久久99国产综合精品女同| 狠狠做深爱婷婷久久综合一区| 亚洲黄一区二区| 日本精品免费观看| 国产69精品99久久久久久宅男| 午夜精品久久久久久99热软件| 57pao国产成人免费| 国产精品丝袜视频| 亚洲免费av电影| 色七七影院综合| 成人妇女淫片aaaa视频| 国产精品久久久久一区二区| 色偷偷噜噜噜亚洲男人| 8090理伦午夜在线电影| 4k岛国日韩精品**专区| 欧美大肥婆大肥bbbbb| 九九热视频这里只有精品| 国产成人啪精品视频免费网| 欧美小视频在线| 欧美激情一区二区三级高清视频| 欧美网站在线观看| 精品亚洲一区二区三区在线观看| 日韩av电影手机在线观看| 91精品91久久久久久| 久久久久99精品久久久久| 国产精品揄拍500视频| 国产精品成人一区二区三区吃奶| 91九色国产在线| 日韩av大片在线| 久久久人成影片一区二区三区观看| 国产成人自拍视频在线观看| 亚洲欧美中文字幕在线一区| 欧美在线性爱视频| 国产精品直播网红| 欧美精品一区二区三区国产精品| 国产精品九九久久久久久久| 91sa在线看| 中文字幕日韩欧美| 久久久久亚洲精品国产| 日韩欧美在线视频观看| 欧美激情精品久久久久久蜜臀| 成人妇女淫片aaaa视频| 午夜欧美不卡精品aaaaa| 欧美成人精品在线| 亚洲影影院av| 中文字幕少妇一区二区三区| 精品无人区太爽高潮在线播放| 国内精品伊人久久| 色偷偷88888欧美精品久久久| 91高清免费视频| 亚洲欧洲成视频免费观看| 久久久久国产精品一区| 亚洲福利视频免费观看| 久久综合网hezyo| 在线丨暗呦小u女国产精品| 欧美最顶级的aⅴ艳星| 成人免费视频网址| 亚洲精品视频在线播放| 深夜精品寂寞黄网站在线观看| 日本精品一区二区三区在线播放视频| 国产精品久久久久久久午夜| 久久久视频在线| 91精品久久久久久久久中文字幕| 国产精品专区一| 国产欧美在线看| 久久韩国免费视频| 亚洲精品99久久久久| 精品久久久一区| xxxxx91麻豆| 欧美色另类天堂2015| 亚洲国产欧美一区二区丝袜黑人| 精品亚洲aⅴ在线观看| 91精品久久久久久久久久另类| 国产丝袜一区二区三区免费视频| 久青草国产97香蕉在线视频| 日韩在线视频中文字幕| 亚洲人成电影在线观看天堂色| 清纯唯美日韩制服另类| 久久久久久尹人网香蕉| 黑人巨大精品欧美一区免费视频| 午夜精品理论片| 久99久在线视频| 亚洲va电影大全| 久久久久免费视频| 色婷婷综合久久久久中文字幕1| 日韩精品极品毛片系列视频| 国产精品入口尤物| 国产精品久久久久久久久久小说| 久久精品2019中文字幕| 亚洲欧美日韩中文在线制服| 高清欧美一区二区三区| 日韩欧美999| 国产一区二区三区视频在线观看| 欧美一级在线播放| 国产欧美精品久久久| 国产日韩欧美中文在线播放| 亚洲黄页视频免费观看| 国产精品高清在线| 久久久久久久久久久久久久久久久久av| 日韩亚洲欧美中文在线| 亚洲a成v人在线观看| 久久99久久99精品免观看粉嫩| 97超碰国产精品女人人人爽| 不用播放器成人网| 2018国产精品视频| 精品国产欧美一区二区三区成人| 久久精品99国产精品酒店日本| 亚洲男人的天堂在线播放| 国产91色在线|免| 高清视频欧美一级| 成人在线小视频| 亚洲欧美在线播放| 欧美日韩成人在线观看| 亚洲性生活视频| 91日韩在线播放| 综合国产在线观看| 成人做爰www免费看视频网站| 亚洲片国产一区一级在线观看| 国产精品亚洲一区二区三区| 中文字幕成人精品久久不卡| 欧美第一页在线| 国内精品久久久久久| 精品少妇v888av| 91免费看片网站| 国产欧美日韩视频| 69国产精品成人在线播放| 亚洲精品视频在线观看视频| 欧美极品少妇xxxxⅹ免费视频| 欧美性猛交丰臀xxxxx网站| 亚洲国产精品yw在线观看| 91精品国产综合久久久久久蜜臀| 日韩av片永久免费网站| 国产欧洲精品视频| 日韩欧美亚洲成人| 久久久久久网址| 欧美在线视频观看| 精品二区三区线观看| 深夜福利国产精品| 国产精品亚洲第一区| 国产精品男人爽免费视频1| 另类专区欧美制服同性| 大胆人体色综合| 欧美黄色小视频| 亚洲美女又黄又爽在线观看| 欧美电影院免费观看| 精品福利在线看| 2019中文字幕全在线观看| 精品国产鲁一鲁一区二区张丽| 大量国产精品视频| 亚洲精品电影网站| 亚洲国产成人在线播放| 国产精品扒开腿做爽爽爽视频| 91日本在线视频| 欧美日韩国产成人| 亚洲欧美国产一区二区三区| 久久福利视频导航| 九九热r在线视频精品| 91高潮精品免费porn| 国产精品第三页| 成人免费福利在线| 91av在线免费观看| 精品久久久91|