检测到具有不兼容类型的二元运算符。发现操作数类型 edm.string 和 edm.guid 的种类相等

A binary operator with incompatible types was detected. Found operand types edm.string and edm.guid for kind equal

我使用 breeze 谓词实现了一个过滤器。将 BreezeJs 和 ASP.NET WebAPI(Breeze 服务器端)与 Entity Framework

一起使用

谓词如下所示:

var predicate = breezeProvider.breeze.Predicate.create('serialNumber', '==', $scope.filter.serialNumber);
predicates.push(predicate);

当我执行查询时。 Breeze 抛出异常并显示以下消息:

A binary operator with incompatible types was detected. Found operand types edm.string and edm.guid for kind equal

$scope.filter.serialNumber 是一个字符串,serialNumber 是一个 GUID 属性

url如下

http://localhost:51969/breeze/WarehouseProductTransactions/GetProducts?$filter=(StatusId ne 3d) and (WarehouseId eq 1d) and (AuthorizedADUserId eq 'bTdbnW8t6Uu4D4KHCoQOhg==') and (SerialNumber eq guid'1b9d065e-eb48-4f3d-883c-2c841771a3e8')&$orderby=Id&$top=5&$expand=Inventory,AuthorizedADUser&$inlinecount=allpages&)

注意片段:

(SerialNumber eq guid'1b9d065e-eb48-4f3d-883c-2c841771a3e8')

我的服务器端如下:

[EnableBreezeQuery(MaxNodeCount = 200)]
public IQueryable<WarehouseProductTransactionDetail> GetProducts()
{
    return _contextProvider.Context.WarehouseProductTransactionDetails;
}

我正在想办法解决这种情况,但不知道。

感谢任何帮助

我在 Breeze 查询中比较 userId 时遇到了同样的问题。 Breeze 在 OData 查询中追加 'guid'。

我可以通过将 .toType("entityTypeName") 附加到 breeze 查询来解决这个问题。

let query = new breeze.EntityQuery().from('orders');          
let predicate = breeze.Predicate.create("CreatedBy", "==", userId);


query = query.where(predicate).toType("Order");