首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将IQueryable<T>转换为IQueryable<Y>

将IQueryable<T>转换为IQueryable<Y>
EN

Stack Overflow用户
提问于 2012-04-16 22:38:36
回答 1查看 476关注 0票数 2

我正在尝试这样做:我首先使用EF代码来映射一个旧的现有数据库。有许多类型错误的字段(例如: char(1)被用作布尔值),所以我为我的db上下文创建了一个包装类,它可以完美地映射到数据库表。现在,我想在我的存储库中公开我的实体类型的IQueryable。请看我的示例:

代码语言:javascript
复制
public class MyContext:DbContext
{
    public DbSet<WrappedEntity> WrapperEntities;
}

public class Repository
{
    private MyContext _context;

    //contructors omitted

    public IQueryable<Entity> GetEntities()
    {
        return _context.WrapperEntities; //doesn't compile, I need some convertion here
    }
}

我已经有了我的转换例程,唯一缺少的是一种在不公开WrappedEntity类的情况下通过我的存储库查询我的DbContext的方法,这是可能的吗?

谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-04-17 03:52:50

通常使用Queryable.Select进行投影以更改查询的类型……

代码语言:javascript
复制
public IQueryable<Entity> GetEntities()
{
  return _context.WrapperEntities.Select(x => new Entity(){...});
} 
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10176228

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档