Как отсортировать с помощью оператора CASE в EntityDataSource? - PullRequest
2 голосов
/ 26 ноября 2011

Я использую оператор CASE в своем EntityDataSource для пользовательской сортировки.Рассмотрим следующий код:

<asp:EntityDataSource ID="myEntityDataSource" runat="server" 
    ConnectionString="name=MySQLEntities1" 
    DefaultContainerName="MySQLEntities1" 
    EnableFlattening="False" 
    EntitySetName="Persons" 
    EntityTypeFilter="Persons"
    OrderBy="it.[Pack], 
             CASE it.[Type] 
                WHEN 'MAN' THEN 1 
                WHEN 'VROUW' THEN 2 
                WHEN 'KIND' THEN 3 
             END, 
             it.[BirthDate] ASC" />

В T-SQL это был бы совершенно нормальный способ сортировки, но при использовании в EntityDataSource выдается следующее исключение:

Синтаксис запроса недействителен.Рядом с идентификатором 'it', строка 11, столбец 21.

Как заставить этот тип сортировки работать в моем EntityDataSource?

1 Ответ

3 голосов
/ 28 ноября 2011

Я пробовал то же самое сегодня. На Справочном сайте Entity SQL я обнаружил, что вы, очевидно, должны использовать CASE WHEN и не можете использовать CASE [value] WHEN. Этот подход, хотя и не такой, как в T-SQL, сработал для меня. Итак, ваш код должен выглядеть так:

<asp:EntityDataSource ID="myEntityDataSource" runat="server" 
ConnectionString="name=MySQLEntities1"      
DefaultContainerName="MySQLEntities1"      
EnableFlattening="False"      
EntitySetName="Persons"      
EntityTypeFilter="Persons"     
OrderBy="it.[Pack],               
CASE 
WHEN it.[Type] = 'MAN' THEN 1                  
WHEN it.[Type] = 'VROUW' THEN 2                  
WHEN it.[Type] = 'KIND' THEN 3 END, it.[BirthDate] ASC" />

MSDN Entity SQL Reference: 'CASE'

...