[解決済み] SqlConnectionを "open/close "するか、"keep open "するか?
2022-07-05 05:40:27
質問
私のビジネスロジックは、静的メソッドを持つ単純な静的クラスで実装されています。これらの各メソッドは、呼び出されたときにSQL接続をオープン/クローズします。
public static void DoSomething()
{
using (SqlConnection connection = new SqlConnection("..."))
{
connection.Open();
// ...
connection.Close();
}
}
しかし、接続オブジェクトを渡して、接続を開いたり閉じたりするのを回避するために、私は パフォーマンスの節約になります。 . 私はずいぶん前に を使ってテストしました。 クラス(SqlConnectionについては不明)を使ってテストを行い、(私が覚えている限り)このように動作するように確かに助けられました。
//pass around the connection object into the method
public static void DoSomething(SqlConnection connection)
{
bool openConn = (connection.State == ConnectionState.Open);
if (!openConn)
{
connection.Open();
}
// ....
if (openConn)
{
connection.Close();
}
}
そこで質問ですが、(a)の方法と(b)の方法のどちらを選べばいいのでしょうか?他のstackoverflowの質問でコネクションプーリングがパフォーマンスを救ったというのを読みましたが、私は全く気にする必要はないですね...。
PS. これはASP.NETのアプリで、接続はWebリクエストの間だけ存在します。win-appやサービスではありません。
どのように解決するのですか?
オプションaにこだわる .
コネクションプーリングは、あなたの味方です。
関連
-
[解決済み】プログラム実行中に1秒待つ
-
[解決済み】スクリプトクラスが見つからないので、スクリプトコンポーネントを追加できない?
-
[解決済み】WebForms UnobtrusiveValidationModeは、jqueryのScriptResourceMappingを必要とする
-
解決済み] Critical error detected c0000374 - C++ dll returns pointer off allocated memory to C# [解決済み] Critical error detected c0000374 - C++ dll returns pointer off allocated memory to C#.
-
[解決済み】C#はJavaのcharAt()と同等?)
-
[解決済み】URLから画像をダウンロードする方法
-
[解決済み】画像のペイントにTextureBrushを使用する方法
-
[解決済み】一部のマシンでTransactionScopeが自動的にMSDTCにエスカレートする?
-
[解決済み] [Solved] SqlConnectionが自動的にアンビエントTransactionScopeトランザクションに参加するのは、どのような状況においてですか?
-
[解決済み] using" ブロックで、SqlConnection は return または exception で閉じますか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] [Solved] 1つ以上のエンティティで検証に失敗しました。詳細は'EntityValidationErrors'プロパティを参照してください [重複]。
-
[解決済み] エンティティタイプ <type> は、現在のコンテキストのモデルの一部ではありません。
-
解決済み] Critical error detected c0000374 - C++ dll returns pointer off allocated memory to C# [解決済み] Critical error detected c0000374 - C++ dll returns pointer off allocated memory to C#.
-
[解決済み】ソケットのアドレス(プロトコル/ネットワークアドレス/ポート)は、通常1つしか使用できない?
-
[解決済み] DBNullから他の型にオブジェクトをキャストすることができない
-
[解決済み】バックスラッシュを含むパス文字列のエスケープシーケンスが認識されない件
-
[解決済み】なぜこのコードはInvalidOperationExceptionを投げるのですか?
-
[解決済み] ...基礎となる接続は閉じられました。予期しないエラーが受信で発生しました
-
[解決済み】「namespace」なのに「type」のように使われる。
-
VSでscanfエラーを恒久的に解決するには、ソースファイルを作成し、自動的に#define _CRT_SECURE_NO_WARNINGS 1を追加してください。