Ceci est très confus, j'utilise AsDataView pour lier résultat de la requête à un DGV et il fonctionne très bien avec les éléments suivants:Reliure requête LINQ to DataGridView
var query = from c in myDatabaseDataSet.Diamond where c.p_Id == p_Id select c;
dataGridView1.DataSource = query.AsDataView();
Cependant, celui-ci se traduit par une erreur:
var query = from item in myDatabaseDataSet.Items
where item.p_Id == p_Id
join diamond in myDatabaseDataSet.Diamond
on item.p_Id equals diamond.p_Id
join category in myDatabaseDataSet.DiamondCategory
on diamond.dc_Id equals category.dc_Id
select new
{
Product = item.p_Name,
Weight = diamond.d_Weight,
Category = category.dc_Name
};
dataGridView1.DataSource = query.AsDataView();
erreur:
Instance argument: cannot convert from
'System.Collections.Generic.IEnumerable<AnonymousType#1>' to
'System.Data.DataTable'
AsDataView ne se présente pas dans la requête (Liste).. Pourquoi est-ce arrivé? Comment lier la requête ci-dessus à la dgv alors ?.
Jetez un oeil à ce lien: [LINQ to DataTable] (http://weblogs.asp.net/stevesloka/archive/2008/01/28/linq-to-datatable.aspx) Peut-être ici pouvez trouver la réponse: [Tapez erreur de conversion en utilisant LINQ avec un DataSet] (http://social.msdn.microsoft.com/Forums/en-US/csharplanguage/thread/bce2aced-2284-498a-b206-a9203cd19937) –