I have 3 entities: RatedPrice, DailyPri开发者_开发百科ce and UtilizePrice.
Each entity has Code member.I would like to write a lambda query that returns IQueryable of the three sorted by Code member. I know I need to use somewhere in Union but I don't know how. Moreover, all the 3 entities has diffrences but are implements IPrice.
How can I do the query?
You must use something like this:
var data = ctx.RatedPrices.Select(p => new { p.Code, p.Price })
              .Concat(ctx.DailyPrices.Select(p => new { p.Code, p.Price })
                         .Contact(ctx.UtilizePrices.Select(p => new { p.Code, p.Price }))
              .OrderBy(p => p.Code);
Entity framework and linq-to-entities don't know what is the interface. You must use projection to some not mapped type (anonymous in the example) and deal with the result. Because you don't use entity inheritance from some base Price (otherwise you would not need this) you cannot expect that EF will return you instances of RetedPrice, DailyPrice and UtilizePrice in single result set.
Something like this maybe
var list = listRatedPrice.Cast<IPrice>()
.Concat(listDailyPrice.Cast<IPrice>()
.Concat(listUtilizePrice.Cast<IPrice>))).Orderby(p => p.Code);
 
         
                                         
                                         
                                         
                                        ![Interactive visualization of a graph in python [closed]](https://www.devze.com/res/2023/04-10/09/92d32fe8c0d22fb96bd6f6e8b7d1f457.gif) 
                                         
                                         
                                         
                                         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论