SELECT [c].[Id], [c].[TimeStamp], [c].[FirstName], [c].[FullName],
[c].[LastName]
FROM [Dbo].[Customers] AS [c]
ORDER BY [c].[LastName], [c].[FirstName]
Сортировка записей в обратном порядке
Метод Reverse()
меняет порядок сортировки на противоположный, как видно в представленном далее тесте:
[Fact]
public void ShouldSortByFirstNameThenLastNameUsingReverse()
{
// Сортировать по фамилии, затем по имени,
// и изменить порядок сортировки на противоположный.
var query = Context.Customers
.OrderBy(x => x.PersonalInformation.LastName)
.ThenBy(x => x.PersonalInformation.FirstName)
.Reverse();
var qs = query.ToQueryString();
var customers = query.ToList();
// Если есть только один пользователь, то проверять нечего.
if (customers.Count <= 1) { return; }
for (int x = 0; x < customers.Count - 1; x++)
{
var pi1 = customers[x].PersonalInformation;
var pi2 = customers[x + 1].PersonalInformation;
var compareLastName = string.Compare(pi1.LastName,
pi2.LastName, StringComparison.CurrentCultureIgnoreCase);
Assert.True(compareLastName >= 0);
if (compareLastName != 0) continue;
var compareFirstName = string.Compare(pi1.FirstName,
pi2.FirstName, StringComparison.CurrentCultureIgnoreCase);
Assert.True(compareFirstName >= 0);
}
}
Вот во что транслируется предыдущий запрос LINQ:
SELECT [c].[Id], [c].[TimeStamp], [c].[FirstName], [c].[FullName],
[c].[LastName] FROM [Dbo].[Customers] AS [c]
ORDER BY [c].[LastName] DESC, [c].[FirstName] DESC
Извлечение одиночной записи
Существуют три главных метода для возвращения одиночной записи посредством запроса: First()/FirstOrDefault()
, Last()/LastOrDefault()
и Single()/SingleOrDefault()
. Хотя все они возвращают одиночную запись, принятые в них подходы отличаются. Методы и их варианты более подробно описаны ниже.
• Метод First()
возвращает первую запись, которая соответствует условию запроса и любым конструкциям упорядочения. Если конструкции упорядочения не указаны, то возвращаемая запись основывается на порядке, установленном в базе данных. Если запись не возвращается, тогда генерируется исключение.
• Поведение метода FirstOrDefault()
совпадает с поведением First()
, но при отсутствии записей, соответствующих запросу, FirstOrDefault()
возвращает стандартное значение для типа (null
).
• Метод Single()
возвращает первую запись, которая соответствует условию запроса и любым конструкциям упорядочения. Если конструкции упорядочения не указаны, то возвращаемая запись основывается на порядке, установленном в базе данных. Если запросу не соответствует одна или большее число записей, тогда генерируется исключение.
• Поведение метода SingleOrDefault()
совпадает с поведением Single()
, но при отсутствии записей, соответствующих запросу, SingleOrDefault()
возвращает стандартное значение для типа (null
).
• Метод Last()
возвращает последнюю запись, которая соответствует условию запроса и любым конструкциям упорядочения. Если конструкции упорядочения не указаны, то возвращаемая запись основывается на порядке, установленном в базе данных. Если запись не возвращается, тогда генерируется исключение.
• Поведение метода LastOrDefault()
совпадает с поведением Last()
, но при отсутствии записей, соответствующих запросу, LastOrDefault()
возвращает стандартное значение для типа (null
).
Все методы могут также принимать Expression
(лямбда-выражение) для фильтрации результирующего набора. Это означает, что вы можете помещать выражение Where()
внутрь вызова First()/Single()
. Следующие операторы эквивалентны: