Maison >développement back-end >C++ >Comment puis-je effectuer des requêtes LINQ sur DataTables?
Bien que l'on pense généralement que le datatatable ne peut pas être utilisé directement, cela peut en fait être réalisé grâce à certaines techniques. DataTable n'implémente pas l'interface
par défaut, il ne peut donc pas interroger directement sa collection de lignes.
IEnumerable<T>
La solution consiste à utiliser la méthode d'extension
. En appelant cette méthode sur DataTable, vous pouvez obtenir un objet System.Data.DataSetExtensions
, puis vous pouvez l'utiliser pour la requête LINQ. AsEnumerable()
IEnumerable<DataRow>
Par exemple, les demandes suivantes renvoient toutes les lignes qui
myDataTable
RowNo
Vous pouvez également utiliser l'expression de lambda pour créer une requête Linq:
<code class="language-csharp">var results = from myRow in myDataTable.AsEnumerable() where myRow.Field<int>("RowNo") == 1 select myRow;</code>
Veuillez noter que vous devez ajouter une référence à l'assemblage
du projet pour accéder à ces extensions.<code class="language-csharp">var result = myDataTable.AsEnumerable() .Where(myRow => myRow.Field<int>("RowNo") == 1);</code>
Si vous avez besoin de convertir les résultats de la requête System.Data.DataSetExtensions
Retour à DataTable, vous pouvez utiliser la méthode d'extension
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!