ASP.NET Web API返回可查询的DTO?
发布时间:2020-09-21 14:02:18 所属栏目:asp.Net 来源:互联网
导读:我使用ASP.NET Web API构建了一个不错的API,但是我猜想从我的上下文(实体框架)AsQueryable返回实体是不对的,所以我将所有内容映射到DTO对象. 我还不太明白,我如何保持我的上下文可以查询,但仍然只返回DTO而不是实体?还是这不可能? 这是我的代码: public IQ
我使用ASP.NET Web API构建了一个不错的API,但是我猜想从我的上下文(实体框架)AsQueryable返回实体是不对的,所以我将所有内容映射到DTO对象. 我还不太明白,我如何保持我的上下文可以查询,但仍然只返回DTO而不是实体?还是这不可能? 这是我的代码: public IQueryable<ItemDto> Get() { using (EfContext context = new EfContext()) { Mapper.CreateMap<Item,ItemDto>() .ForMember(itemDto => itemDto.Category,mce => mce.MapFrom(item => item.Category.Name)); IEnumerable<ItemDto> data = Mapper.Map<IEnumerable<Item>,IEnumerable<ItemDto>>(context.Items .OrderByDescending(x => x.PubDate) .Take(20)); return data.AsQueryable(); } } 正如你可以看到我加载数据,并使这个小的IEnumerable集合可查询.问题是,为这段代码生成的查询可能是非常低效的,因为它首先加载所有项目(或至少20个第一个项目),然后过滤输出. 我希望我描述我的问题尽可能好,这有点难以解释.我在Google上找不到任何内容. 解决方法不要先选择内存中的所有内容.做这样的事情:public IQueryable<ItemDto> Get() { using (EfContext context = new EfContext()) { var query = from item in context.Items select Mapper.Map<Item,ItemDto>(item) return query.OrderByDescending(x => x.PubDate).Take(20)); } } BTW以下代码是您想要执行的操作,例如在静态构造函数或WebApiConfig.cs文件中. Mapper.CreateMap<Item,ItemDto>() .ForMember(itemDto => itemDto.Category,mce => mce.MapFrom(item => item.Category.Name)); (编辑:鄂州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- ASP.NET:web.config在哪里/如何缓存?
- IIS 7中为ASP.NET缺少MIME类型404.17
- 有什么好的参考或工具可用于将ASP转换为ASP.NET?
- .Net 更容易的使用配置文件 SuperConfig
- asp.net-mvc – ASP.NET MVC V2 – 好友类
- 在asp.net中使用eval(“”)
- asp.net-mvc – 如何在扩展方法中使用HTML帮助器方法?
- 为熟悉ASP.NET Web表单开发的人建议MVC3的周末学习轨道
- asp.net-mvc – asp.net mvc – string或int的路由(即/ typ
- asp.net-mvc – AppDomain.GetAssemblies和BuildManager.Ge