做跨境电商在什么网站选品,wordpress邮件找客户端,义乌搭建网站,六安品牌网站建设怎么样最近做了一个小项目#xff0c;其中用到了 WCF Data Service#xff0c;之前是叫 ADO.NET Data Service 的。关于WCF Data Service#xff0c;博客园里的介绍并不多#xff0c;但它确实是个很好的框架。可以很方便地通HTTP来访问数据库#xff0c;如果你是做富客户端开发的…最近做了一个小项目其中用到了 WCF Data Service之前是叫 ADO.NET Data Service 的。关于WCF Data Service博客园里的介绍并不多但它确实是个很好的框架。可以很方便地通HTTP来访问数据库如果你是做富客户端开发的用它绝对能大大减少你的工作量。出于对这个框架的喜爱于是把自己的一些使用经验写下来并且希望有更多的人能够用上。
OData简介
说起 WCF Data Service 不得不说的是 OData。对于一个标准的 Web 服务它往往会提供了一些功能比如说订货、退货这些然后使用者通过HTTP协议来使用这些功能。这是面向服务的基本思想然而面前服务有一些缺点很多时候没法准确预测到用户需要什么。因此总是要不断地增加新的接口不断地修改返回的对象。
另一种方法是所谓的资源为导向的架构ROA暴露Web服务的资源并且用户能够对各种对资源进行实时的查询具有表现数据和整合数据的能力。类似于使用 SQL 在数据库中查询数据。唯一的区别是ROA你通过URL创建查询。
OData是一个协议规定公开数据的Web服务的特点。下面这段话是OData的定义 Open Data Protocol 开放数据协议OData是用来查询和更新数据的一种Web协议其提供了把存在于应用程序中的数据暴露出来的方式。OData运用且构建于很多 Web技术之上比如HTTP、Atom Publishing ProtocolAtomPub和JSON提供了从各种应用程序、服务和存储库中访问信息的能力。OData被用来从各种数据源中暴露和访问信息 这些数据源包括但不限于关系数据库、文件系统、内容管理系统和传统Web站点。 OData协议概述
正如上面所提到的OData服务通过Web服务来透露所提供的资源。然后您可以通过URL访问这些资源。 OData 协议指明了如何通过HTTP来查询数据。基本原则是你可以输入某些带参数的 URL 来对资源进行查询。
下面是一些你可以使用的 OData 公共服务更多可以使用的 OData 服务你可以通过访问 OData 的官网来获得。
http://services.odata.org/WebSite/OData.svc/http://services.odata.org/OData/OData.svc/http://services.odata.org/Northwind/Northwind.svc/
在介绍使用 OData 协议进行查询时将会使用这些公开的 OData 服务。下面以 http://services.odata.org/Northwind/Northwind.svc/ 为例在浏览器中输入刚网址你将会看到 从上图中你可以看到该服务提供了 Products、Advertisements、Categories、Suppliers 这些资源。通过输入下面这些 URL 即可对这些资源进行访问。例如
http://services.odata.org/Northwind/Northwind.svc/Productshttp://services.odata.org/Northwind/Northwind.svc/Categorieshttp://services.odata.org/Northwind/Northwind.svc/Suppliers
这些查询将会返回该资源的所有基于 XML-Atom 格式的数据。例如下图是 Products 的数据。 格式输出的数据
默认的格式是 XML-Atom当然你也可以其它格式当前还支持 JSON 格式。只要在URL上添加 $formatjson 参数即可获得 json 格式的数据。
http://services.odata.org/Northwind/Northwind.svc/Products?$formatjsonhttp://services.odata.org/Northwind/Northwind.svc/Categories?$formatjsonhttp://services.odata.org/Northwind/Northwind.svc/Suppliers?$formatjson选取字段
默认情况下是会返回所有字段的但很多时候你可能只是需要获取其它的某些字段。例如下面的查询中只返回 ID 和 Name 字段。
http://services.odata.org/Northwind/Northwind.svc/Products?$selectProductID,ProductName$formatjson展开
很多时候我们还需要将关联的导航属性取出来。打开下面的 URLhttp://services.odata.org/Northwind/Northwind.svc/$metadata
从下面这个图可以看到Product 还有 Category、Order_Details、Supplier 三个导航属性。 通过 expand 参数可以把相关的导航属性的数据一并取出。输入 http://services.odata.org/Northwind/Northwind.svc/Products?$formatjson$expandSupplier 当然你也可以一次展开多个导航属性多个导航属性之间使用“,”分隔例如
ttp://services.odata.org/Northwind/Northwind.svc/Products?$formatjson$expandSupplier,Category
分页
通过 $top 和 $skip 参数可以进行分页显示例如
http://services.odata.org/Northwind/Northwind.svc/Products?$formatjson$skip10$take10
过滤
使用 $filter参数可以对数据进行过滤例如
http://services.odata.org/Northwind/Northwind.svc/Products?$formatjsonProductId gt 4
排序
使用 $orderby 参数可以对数据进行排序例如
http://services.odata.org/Northwind/Northwind.svc/Products?$formatjson$orderbyProduct
升序
http://services.odata.org/Northwind/Northwind.svc/Products?$formatjson$orderbyProduct asc
降序
http://services.odata.org/Northwind/Northwind.svc/Products?$formatjson$orderbyProduct desc 关于关键字的详细使用可以参考 OData 官网的文档。
http://www.odata.org/documentation/odata-v2-documentation/uri-conventions/