Привязка запроса LINQ к DataGridView

Это очень запутанно, я использую AsDataView для привязки результата запроса к dgv, и он отлично работает со следующим:

var query = from c in myDatabaseDataSet.Diamond where c.p_Id == p_Id select c;
dataGridView1.DataSource = query.AsDataView();

однако, это приводит к ошибке:

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();

ошибка:

Instance argument: cannot convert from
'System.Collections.Generic.IEnumerable<AnonymousType#1>' to 
'System.Data.DataTable'

AsDataView не отображается в запросе.(Список.) Почему это происходит? Как привязать запрос выше к dgv?.

2 ответов


подпись AsDataView следующим образом:

public static DataView AsDataView(
    this DataTable table
)

единственный параметр -DataTable.

запрос у вас возвращает IEnumerable анонимного типа, который не имеет неявного преобразования в DataTable (или последовательность DataRow экземпляры, в этом случае вы можете использовать это, чтобы помочь вам создать DataTable).

вам нужно вернуть результаты в DataTable или что-то, что вы можете преобразовать в DataTable, и тогда это сработает.

в вашем конкретном случае кажется, что вы использовали (или используете)типизированные наборы данных. Если это так, то вы должны иметь возможность принимать выбранные значения, а затем создавать новые типизированные экземпляры DataRow (для вас должны быть заводские методы), которые затем могут быть помещены в типизированный DataTable, который можно вызвать AsDataView.


просто преобразуйте результат в список и привяжите его к своей сетке.

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
    }.ToList();
dataGridView1.DataSource = query;