Dies ist sehr verwirrend, ich AsDataView verwenden, um Abfrageergebnis an eine dgv zu binden und es funktioniert gut mit den folgenden:Bindung LINQ-Abfrage an Datagridview
var query = from c in myDatabaseDataSet.Diamond where c.p_Id == p_Id select c;
dataGridView1.DataSource = query.AsDataView();
Doch diese eine führt zu einem Fehler:
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();
Fehler:
Instance argument: cannot convert from
'System.Collections.Generic.IEnumerable<AnonymousType#1>' to
'System.Data.DataTable'
AsDataView zeigen sich nicht in Abfrage (List).. Warum ist das passiert? Wie bindet man die obige Abfrage an den dgv?
unter diesem Link Werfen Sie einen Blick: [LINQ to Datatable] (http://weblogs.asp.net/stevesloka/archive/2008/01/28/linq-to-datatable.aspx) Sie vielleicht hier kann die Antwort finden: [Geben Sie Konvertierungsfehler mit LINQ mit einem DataSet] (http://social.msdn.microsoft.com/Forums/en-US/csharplanguage/thread/bce2aced-2284-498a-b206-a9203cd19937) –