- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试创建 Odata 端点,但每当我尝试执行任何涉及日期的查询时都会收到此错误。
我在下面的非常简单示例中重新创建了它。
数据库表
EDMX(片段)
<edmx:ConceptualModels>
<Schema Namespace="DataWarehouseModel" Alias="Self" annotation:UseStrongSpatialTypes="false" xmlns:annotation="http://schemas.microsoft.com/ado/2009/02/edm/annotation" xmlns="http://schemas.microsoft.com/ado/2009/11/edm">
<EntityContainer Name="DataWarehouseEntities1" annotation:LazyLoadingEnabled="true">
<EntitySet Name="People" EntityType="DataWarehouseModel.Person" />
</EntityContainer>
<EntityType Name="Person">
<Key>
<PropertyRef Name="ID" />
</Key>
<Property Name="ID" Type="Int32" Nullable="false" annotation:StoreGeneratedPattern="Identity" />
<Property Name="FirstName" Type="String" Nullable="false" MaxLength="50" FixedLength="false" Unicode="true" />
<Property Name="LastName" Type="String" Nullable="false" MaxLength="50" FixedLength="false" Unicode="true" />
<Property Name="DOB" Type="DateTime" Nullable="false" Precision="3" />
</EntityType>
</Schema>
</edmx:ConceptualModels>
<!-- C-S mapping content -->
<edmx:Mappings>
<Mapping Space="C-S" xmlns="http://schemas.microsoft.com/ado/2009/11/mapping/cs">
<EntityContainerMapping StorageEntityContainer="DataWarehouseModelStoreContainer" CdmEntityContainer="DataWarehouseEntities1">
<EntitySetMapping Name="People">
<EntityTypeMapping TypeName="DataWarehouseModel.Person">
<MappingFragment StoreEntitySet="Person">
<ScalarProperty Name="DOB" ColumnName="DOB" />
<ScalarProperty Name="LastName" ColumnName="LastName" />
<ScalarProperty Name="FirstName" ColumnName="FirstName" />
<ScalarProperty Name="ID" ColumnName="ID" />
</MappingFragment>
</EntityTypeMapping>
</EntitySetMapping>
</EntityContainerMapping>
</Mapping>
</edmx:Mappings>
型号
public partial class Person
{
[Key]public int ID { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public System.DateTime DOB { get; set; }
}
Controller
public class PersonController : ODataController
{
private DataWarehouseServiceContext db = new DataWarehouseServiceContext();
private bool PersonExists(int key)
{
return db.Persons.Any(p => p.ID == key);
}
[EnableQuery]
public IQueryable<Person> Get()
{
return db.Persons;
}
protected override void Dispose(bool disposing)
{
db.Dispose();
base.Dispose(disposing);
}
}
查询
http://localhost:53205/OData/Person?$top=20&$filter=DOB eq 1972-11-20T00:00:00.000Z
http://localhost:53205/OData/Person?$top=20&$filter=DOB lt 1972-11-20T00:00:00.000Z
等等
所有失败并显示以下行的消息:-
The query specified in the URI is not valid. The binary operator LessThan is not defined for the types 'System.Nullable`1[System.DateTime]' and 'System.Nullable`1[System.DateTimeOffset]'.
有人能帮忙吗?
最佳答案
这里的问题是,虽然 Microsoft 有 partly添加了 DateTime 支持(see comments),OData V4 不包括 DateTime 作为原始类型。这意味着您的过滤器仍然需要使用 DateTimeOffset。
虽然不理想,但将 DateTime 转换为 DateTimeOffset 似乎可以解决问题。
/OData/Person?$top=20&$filter=cast(DOB,'Edm.DateTimeOffset') eq 1972-11-20T00:00:00.000Z
关于.net - 二元运算符 LessThan 没有为类型 'System.Nullable` 1[System.DateTime ]' and ' System.Nullable`1[System.DateTimeOffset]' 定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28586797/
我正在尝试根据 QDateTime 对 QList 进行排序,但出现以下错误: must use '.*' or '->*' to call pointer-to-member function in
如何在不使用“<”运算符的情况下递归编写一个方法来检查一个数字是否小于另一个数字? 您只能使用加、减、乘和等于运算符。 它必须是递归的 x 和 y 始终为 0 或更大 应返回 boolean 值 如果
我有一个包,我在其中构建表达式树,通过 PredicateBuilder 与 EntityFramework 一起使用: public Expression> constructaPredicate(
正在尝试编译这段代码 import static org.hamcrest.Matchers.is; import static org.hamcrest.number.OrderingCompari
我正在使用这样的东西: schema.number .lessThan( value, `You own only ${value}.`) 它工
在已弃用的 Criteria API 中,我可以执行以下操作: Object value = myFunc(); //this function returns numeric value based
在 JavaFX 中,有一个 IntegerProperty继承方法的类,例如 greaterThan和 lessThan返回 BooleanBinding .但是,不允许使用空值,因为它将值存储为
我想使用从 map 上获取的边界框按地理点查询文档集合。我有界限: 北:50.730 东:-1.861 南方:50.700 西:-1.893 这是我的实际文档结构(基于我期望它返回的值): docum
WHERE [Date] <= CASE WHEN @param = 1 THEN CONVERT(DATE, GETDATE())
System.Threading.Interlocked 对象允许将加法(减法)和比较作为原子操作。似乎不做相等但同时将 GreaterThan/LessThan 作为原子比较的 CompareExc
我正在尝试使用表达式树编写动态 Linq 2 Sql 查询,但出现异常,提示未为 System.String 和 定义 LessThan 和 GreaterThan 运算符>System.String
我正在尝试创建 Odata 端点,但每当我尝试执行任何涉及日期的查询时都会收到此错误。 我在下面的非常简单示例中重新创建了它。 数据库表 EDMX(片段)
我正在尝试创建 Odata 端点,但每当我尝试执行任何涉及日期的查询时都会收到此错误。 我在下面的非常简单示例中重新创建了它。 数据库表 EDMX(片段)
我是一名优秀的程序员,十分优秀!