linq to sql Distinct и orderby - PullRequest
       3

linq to sql Distinct и orderby

30 голосов
/ 01 декабря 2010
var result = table1.Join(table2, o => o.ProgramID, t => t.ProgramID, (o, t) => new { o.ProgramID, t.Program })
         .OrderBy(t => t.Program)
         .Distinct();

приведенный выше оператор linq на самом деле возвращает правильный результат, но сгенерированный sql (ниже) не так прост, как мог бы быть

SELECT [t2].[ProgramID], [t2].[Program]
FROM (
    SELECT DISTINCT [t0].[ProgramID], [t1].[Program]
    FROM [table1] AS [t0]
    INNER JOIN [table2] AS [t1] ON [t0].[ProgramID] = [t1].[ProgramID]
    ) AS [t2]
ORDER BY [t2].[Program]

Я бы подумал, что sql ниже намного чище, но я не уверен в том, что оператор linq достиг этого.

select distinct 
    o.ProgramID, 
    t.Program 
from 
    table1 0 
    inner join table2 t on t.ProgramID = o.ProgramID 
order by t.Program

Заранее спасибо

Ответы [ 3 ]

29 голосов
/ 01 декабря 2010

Не знаю, поможет ли это, но вы можете попробовать что-то вроде этого;

var result = (from o in table1
              join t in table2 on o.ProgramID equals t.ProgramID
              orderby t.Program
              select new { o.ProgramID, t.Program }).Distinct();
10 голосов
/ 14 декабря 2012

Я пробовал это и это работает:

var result = (from o in table1
              join t in table2 on o.ProgramID equals t.ProgramID
              select new { o.ProgramID, t.Program })
              .Distinct().OrderBy(t => t.Program)
                         .ThenBy(t => t.ProgramName)
                         .ThenBy(t => t.Description); 

Сначала вы делаете Distinct, а затем OrderBy, затем OrderBy работает.

4 голосов
/ 01 декабря 2010

Профилируйте два запроса, сравнивая stats-IO и фактический план выполнения.Вполне возможно, что он не имеет никакого значения для SQL-сервера.

Если вы действительно хотите известный TSQL, используйте ExecuteQuery-of-T и передайте TSQL самостоятельно.Может быть, включить некоторые подсказки блокировки (чаще всего: NOLOCK)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...