asp.net-web-api – 没有实体框架的WebAPI ODATA

在Web Api控制器中考虑以下方法
[Queryable(AllowedQueryOptions= AllowedQueryOptions.All)]
public override IQueryable<Mandate> Get()
{
        return new List<Mandate>() { new Mandate() { 
            Id = 1,PolicyNumber = "350000000",OpenPositions = new List<OpenPosition>(){ 
                new OpenPosition(){ Id = 1,Amount =2300 },new OpenPosition(){ Id = 2,Amount =2100 }
            }},new Mandate() { 
                Id = 2,PolicyNumber = "240000000",OpenPositions = new List<OpenPosition>(){ 
                new OpenPosition(){ Id = 3,Amount =2500 },Amount =2100 }
            }

            } }.AsQueryable<Mandate>();
    }

这里列表是手动构建的,如果我浏览到以下url:

http:// localhost:52446 / odata / Mandates?$filter = Id eq 1它从列表中返回正确的项目.

现在很明显,列表更可能是数据库结构.将使用某些ORM检索数据并将其返回到Web API服务.

我不使用实体框架(我不能因为遗留系统).

在这种情况下,我如何使用Web API?如何翻译url参数,以便负责数据访问的层应用过滤器?

解决方法

得到它了.您通过LINQ提供程序向我指出了正确的方向.我发现我可以使用我们正在使用的ORM(OpenAccess)轻松完成.更多信息: http://docs.telerik.com/data-access/developers-guide/using-web-services/asp.net-web-api/developer-guide-wcfservices-web-api-expose-oacontext

相关文章

这篇文章主要讲解了“WPF如何实现带筛选功能的DataGrid”,文...
本篇内容介绍了“基于WPF如何实现3D画廊动画效果”的有关知识...
Some samples are below for ASP.Net web form controls:(fr...
问题描述: 对于未定义为 System.String 的列,唯一有效的值...
最近用到了CalendarExtender,结果不知道为什么发生了错位,...
ASP.NET 2.0 page lifecyle ASP.NET 2.0 event sequence cha...