2

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?

4

1 回答 1

3

我今天也在尝试同样的事情。我在 Entity SQL Reference 站点上发现您显然必须使用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 实体 SQL 参考:“案例”

于 2011-11-28T17:41:57.263 回答