自定义Data Service Providers — (7)交互式查询
2019-07-13 16:42 发布
生成海报
完整教程目录请参见:《 自定义 Data Service Providers — 简介 》
每当我编写一个插件并挂接到框架系统中时,我总是在想:框架系统是如何调用我的插件呢?
我已经习惯这种思维模式,它可以简化我理解其运行的原理。
事实上,在 DSP
开发过程中,我也是用这种方法理解 DataService
的调用过程。
下面我将使用伪代码 来描述这些 DSP
接口是如何被调用的。
场景 —基本查询
想想一下,一个客户端发起一个 Get
请求,例如: /Sample.svc/Products(1)
。
首先发生的是 Data Services
的初始化事件。
// 获取服务提供者
var dataservice = …;
IServiceProvider sp = dataservice as IServiceProvider;
if (sp == null)
{
// 以后再补充这里的代码 !!!
}
// 获取 DSP 各个接口的实现
IDataServiceMetadataProvider mdp =
sp.GetService(typeof(IDataServiceMetadataProvider));
IDataServiceQueryProvider qp =
sp.GetService(typeof(IDataServiceQueryProvider));
// 如有需要,赋值 CurrentDataSource 属性
if (qp.CurrentDataSource == null)
qp.CurrentDataSource = dataservice.CreateDataService();
// 尝试获取名为 Products 资源集
var resourceSet = null;
if (!mdp.TryResolveResourceSet(“Products”, out resourceSet))
throw new Exception(“404”);
// 获取资源集 Products 的查询对象( queryable )
IQueryable queryRoot = qp.GetQueryRootForResourceSet(resourceSet);
// 使用 URL 上的选项(例如 $filter/$select )在现有的查询对象上合并成新的查询表达式
queryRoot = Compose(options, queryRoot);
// 写入回复的“头”部分
WriteStartODataFeed();
// 枚举所有的查询结果
foreach (object resource in queryRoot)
{
// 这里需要获取资源对应的类型。
// 因为结果集中的类型可能是基础类型的派生类型,造成每个实例类型不一样。
ResourceType type = qp.GetResourceType(type);
WriteResource(resource,type);
}
WriteEndODataFeed();
希望通过这段伪代码能够帮助你理解 DSP
在 Data Service
框架中是如何工作的。
下一步
接下来的教程,我们将暂时离开这个查询模型,我们将开始实现服务操作和查询拦截器等内容。
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮