Объединение таблиц в .NET DataSet для отображения в DataGridView

У меня есть две таблицы в наборе данных в .NET. Я хочу присоединиться к ним в столбце идентификаторов. Затем я хочу, чтобы DataGridView отображал два столбца из первой таблицы и один столбец из второй таблицы.

Если это упрощает, связь между двумя таблицами один к одному.

Можно ли это сделать?


person alrashedf    schedule 23.11.2008    source источник


Ответы (2)


Ну, это только для чтения? В .NET 3.5/C# 3.0 вы, вероятно, могли бы довольно легко использовать соединение LINQ и анонимный тип вывода:

        DataTable left = new DataTable
        {
            Columns = { {"PK", typeof(int)}, {"Name", typeof(string)}},
            Rows = {{1,"abc"},{2,"def"}}
        }, right = new DataTable
        {
            Columns = { { "FK", typeof(int) }, { "Value", typeof(decimal) } },
            Rows = { { 1, 123.45M }, { 2, 678.9M } }
        };
        var qry = from x in left.Rows.Cast<DataRow>()
                  join y in right.Rows.Cast<DataRow>()
                  on x.Field<int>("PK") equals y.Field<int>("FK")
                  select new
                  {
                      Name = x.Field<string>("Name"),
                      Value = y.Field<decimal>("Value")
                  };
        var data = qry.ToList();

Затем вы можете привязаться к «Имени» и «Значению» данных. Обратите внимание, что с типизированными наборами данных проще, так как вы можете потерять Cast<> и Field<> мусор.

person Marc Gravell    schedule 23.11.2008

Почему бы не использовать конструктор? Вы помещаете обе таблицы в набор данных, устанавливаете связь и меняете методы Fill/Get примерно так (с «внутренним соединением»):

ВЫБЕРИТЕ Productos.idProducto, Productos.Nombre, Precios.Precio, Tiendas.idTienda, Zonas.Zona,Productos.idZona FROM
Productos INNER JOIN Precios ON Productos.idProducto = Precios.idProducto

person netadictos    schedule 06.08.2009