Dapper propose deux façons de gérer les connexions :
Avec cette approche, vous assumez l'entière responsabilité de l'ouverture et de la fermeture de la connexion, comme si vous travailliez directement avec ADO.NET.
Dapper peut gérer automatiquement l'ouverture et la fermeture des connexions. Ceci est comparable à DataAdapter.Fill(), mais peut ne pas convenir à tous les scénarios.
Il est généralement recommandé de gérer les connexions vous-même si vous fermez les connexions avec une granularité plus large (par exemple, par requête), car cela améliore le contrôle du code.
Quelle que soit l'approche de gestion des connexions, pensez à fermer la connexion pour éviter les fuites de ressources et améliorer les performances en la renvoyant à la connexion pool.
Pour mieux gérer les transactions, pensez à implémenter un modèle UnitOfWork, comme indiqué ci-dessous :
public sealed class UnitOfWork : IUnitOfWork { // Connection and transaction management logic here }
Vos référentiels peuvent alors accepter l'UnitOfWork :
public sealed class MyRepository { public MyRepository(IUnitOfWork unitOfWork) { /* Implementation */ } public MyPoco Get() { /* Implementation using unitOfWork */ } public void Insert(MyPoco poco) { /* Implementation using unitOfWork */ } }
En utilisant un UnitOfWork, vous centralisez le contrôle de la gestion des connexions et transactions, améliorant l'organisation et la maintenabilité du code.
Pour plus de détails sur UnitOfWork, reportez-vous au code source fourni et aux ressources externes.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!