ЛЕВЫЙ НАРУЖНЫЙ РЕЙТИНГ 2 таблицы данных

Я пытаюсь понять, как запросить, предпочтительно с LINQ, 2 таблицы данных. Я хотел бы сделать LEFT OUTER JOIN на них

Datatable1 с col 's: [ID] [colA]
DataTable2 с столбцами: [ID] [ColB] [ColC] ...

Хотите присоединиться к этому идентификатору.

Может кто-нибудь показать мне пример, чтобы я мог применить его к имеющимся у меня данным? заранее спасибо

 Joanna Derks01 мая 2012 г., 21:27

Ответы на вопрос(3)

LEFT OUTER Join

and you should try using @Joanna link.

from x in DataTable1
join y in DataTable2 on x.ID equals y.ID into DataGroup
from item in DataGroup.DefaultIfEmpty(new y.ColB = String.Empty , y.ColC = String.Empty})
select new {x.ColA, item.ColB , item.ColC}

UPDATE

Учитывая, что вы предоставляете, вы должны искать статьи LINQ-Dataset

Вот фрагмент кода

DataTable DataTable1 = new DataTable();
DataTable DataTable2 = new DataTable();

DataTable1.Columns.Add("ID");
DataTable1.Columns.Add("ColA");
DataTable1.Rows.Add(1, "A");
DataTable1.Rows.Add(2, "B");    

DataTable2.Columns.Add("ID");
DataTable2.Columns.Add("ColB");
DataTable2.Rows.Add(1, "B");

var result = from x in DataTable1.AsEnumerable()
             join y in DataTable2.AsEnumerable() on x["ID"] equals y["ID"] into DataGroup                         
             from item in DataGroup.DefaultIfEmpty()
             select new {
                            ID = x["ID"],
                            ColA = x["ColA"],
                            ColB = item == null ? string.Empty : item["ColB"]
                        };
foreach (var s in result)
    Console.WriteLine("{0}", s);
 Kyle01 мая 2012 г., 21:47
Я думаю, что часть того, что смущает меня на вашем примере, и все остальные примеры - это отсутствие x.ID для меня. Должен ли быть x.ID? или я должен делать что-то вроде x.Table.Columns [& quot; ID & quot;] вместо x.ID? Что я могу сделать неправильно, если я не получаю X.ID? Спасибо за помощь.
 01 мая 2012 г., 22:59
@Turbot - лол, это было именно то, что я сделал минуту назад, чтобы обойти передачу в DefaultIfEmpty подряд, но потом я все же нашел способ сделать это.
 01 мая 2012 г., 22:55
обратитесь к сообщению ОБНОВЛЕНИЕ. Вы должны ссылаться на LINQ-Dataset, поскольку вокруг него слишком много конкретных тем LINQ.
 01 мая 2012 г., 22:05
Что ты на сегодня сделал? Можете ли вы рассказать нам больше, почему вы не получаете x.ID?
 Kyle01 мая 2012 г., 22:16
Например, вот код с самого начала, чтобы попытаться максимально приблизить ваш.codepaste.net/ic84es Если я не использую .AsEnumerable (), то это вызывает ошибку в DataTable1, говоря, что GroupJoin не найден. Если я добавлю AsEnumerable (), который, как показал один из примеров, найденных при поиске, относится к datatables, то следующая ошибка - X.ID, потому что нет .ID. Я просто получаю то, что нормально для DataRow. Еще раз спасибо за вашу помощь.
Решение Вопроса

что вы ожидаете, основываясь на заданном наборе результатов:

// create the default row to be used when no value found
var defaultRow = DataTable2.NewRow();
defaultRow[0] = 0;
defaultRow[1] = String.Empty;

// the query
var result = from x in DataTable1.AsEnumerable()
    join y in DataTable2.AsEnumerable() on (string)x["ID"] equals (string)y["ID"] 
             into DataGroup
    from row in DataGroup.DefaultIfEmpty<DataRow>(defaultRow)
    select new {a = x["ColA"], b = (string)row["ColB"]};
 Kyle01 мая 2012 г., 23:10
Похоже, это сработает, и я сейчас пробую. Первоначально моя программа заполняет базы данных, но я сообщу об этом после завершения. Спасибо большое за вашу помощь!

from x in Datatable1
join y in Datatable2 on x.ID equals y.ID
select new {x.colA, y.ColB, y.ColC }
 Kyle01 мая 2012 г., 21:54
Я думаю, что часть того, что смущает меня на вашем примере, и все остальные примеры - это отсутствие x.ID для меня. Должен ли быть x.ID? или я должен делать что-то вроде x.Table.Columns [& quot; ID & quot;] вместо x.ID? Что я могу сделать неправильно, если я не получаю X.ID? Спасибо за помощь.

Ваш ответ на вопрос