Esto es muy confuso, yo uso AsDataView de obligar resultado de la consulta a un vgd y funciona bien con lo siguiente:Encuadernación LINQ consulta a DataGridView
var query = from c in myDatabaseDataSet.Diamond where c.p_Id == p_Id select c;
dataGridView1.DataSource = query.AsDataView();
Sin embargo, este resultado en un error:
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();
error:
Instance argument: cannot convert from
'System.Collections.Generic.IEnumerable<AnonymousType#1>' to
'System.Data.DataTable'
AsDataView no aparece en la consulta (Lista).. ¿Por qué sucede esto? ¿Cómo vincular la consulta anterior al dgv?
Echa un vistazo a este enlace: [LINQ a DataTable] (http://weblogs.asp.net/stevesloka/archive/2008/01/28/linq-to-datatable.aspx) Tal vez aquí se puede encontrar la respuesta: [Escriba el error de conversión usando LINQ con un DataSet] (http://social.msdn.microsoft.com/Forums/en-US/csharplanguage/thread/bce2aced-2284-498a-b206-a9203cd19937) –