Dapper は、接続を処理する 2 つの方法を提供します。
このアプローチでは、ADO.NET を直接操作する場合と同様に、接続の開閉についてはユーザーが全責任を負います。
Dapper は接続の開閉を自動的に処理できます。これは DataAdapter.Fill() に相当しますが、すべてのシナリオに適しているわけではありません。
より広い粒度 (リクエストごとなど) で接続を閉じる場合は、一般的に接続を自分で管理することをお勧めします。コード制御が向上します。
接続管理アプローチに関係なく、リソース リークを回避し、接続に戻すことでパフォーマンスを向上させるために接続を閉じることを忘れないでください。 pool.
トランザクションをより適切に管理するには、以下に示すように UnitOfWork パターンを実装することを検討してください。
public sealed class UnitOfWork : IUnitOfWork { // Connection and transaction management logic here }
これにより、リポジトリが UnitOfWork を受け入れることができます。
public sealed class MyRepository { public MyRepository(IUnitOfWork unitOfWork) { /* Implementation */ } public MyPoco Get() { /* Implementation using unitOfWork */ } public void Insert(MyPoco poco) { /* Implementation using unitOfWork */ } }
UnitOfWork を使用すると、接続管理とトランザクションを制御し、コードの構成と保守性を向上させます。
UnitOfWork の詳細については、提供されているソース コードと外部リソースを参照してください。
以上がDapper を使用するときに接続を適切に閉じるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。