首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在查询文件中正确使用OData v4 DataTimeOffset?

如何在查询文件中正确使用OData v4 DataTimeOffset?
EN

Stack Overflow用户
提问于 2016-05-10 23:20:52
回答 2查看 520关注 0票数 1

我有一个OData v4 WebAPI 2端点:

代码语言:javascript
复制
http://windows-10:8888/Incident

这个端点需要支持对DateTime字段的筛选:

代码语言:javascript
复制
http://windows-10:8888/Incident?$filter=REPORTEDDATE gt DateTimeOffset'2016-05-10%2016:01:53.000'

当我运行这个程序时,我会得到这个错误:

代码语言:javascript
复制
     "The query specified in the URI is not valid. 
    Unrecognized 'Edm.String' literal 'DateTimeOffset'2016-05-10 16:01:53.000'' 
at '16' in 'REPORTEDDATE gt DateTimeOffset'2016-05-10 16:01:53.000''."

用DateTime v4实现这种OData滤波的合适技术是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-05-11 00:07:48

根据规范,http://docs.oasis-open.org/odata/odata/v4.0/odata-v4.0-part2-url-conventions.html第5.1.1.6.1节示例:

http://localhost:23890/People?$expand=Trips($filter=StartsAt%20eq%202014-01-01T01:00:00-08:00)或http://localhost:23890/People?$expand=Trips($filter=StartsAt%20eq%202014-01-01T01:00:00.000-08:00)或http://localhost:23890/People?$expand=Trips($filter=StartsAt%20eq%202014-01-01T01:00:00Z)

我已经验证了Web APi OData或REStier,这很好。

票数 1
EN

Stack Overflow用户

发布于 2016-05-11 00:04:57

在这里找到正确的语法:http://stackoverflow.com/questions/28586797/the-binary-operator-lessthan-is-not-defined-for-the-types-system-nullable1sys

在我的例子中,语法是:

代码语言:javascript
复制
http://windows-10:8888/Incident?$filter=cast(REPORTEDDATE,%27Edm.DateTimeOffset%27)%20gt%20%202016-05-10T22:38:00.000Z
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37150489

复制
相关文章

相似问题

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