如何解决如何在 Drools 的列表中找到每个产品的最大日期
我有一个包含开始和结束日期的产品列表,我必须创建一组规则,我需要在这些规则中逐个处理产品以找出它们的最长日期。例如,
Product(id=1,category=1,start=1/1/20,end=12/31/20)
Product(id=1,start=1/1/21,end=12/31/21)
Product(id=1,start=1/1/22,end=12/31/22)
Product(id=1,category=2,start=1/1/23,end=12/31/23)
Product(id=2,end=12/31/20)
Product(id=2,end=12/31/21)
Product(id=2,end=12/31/22)
Product(id=2,end=12/31/24)
Product(id=3,end=12/31/20)
Product(id=3,end=12/31/21)
...
所以我需要为每个产品 ID 和类别选择具有最大结束日期的行。我怎样才能在 Drools 中做到这一点?
我已经试过了,但我怀疑这是否正确。
Product($start:start,$cat:category,$id : id)
not(exists(Product(start>$start,category==$cat,id==$id)))
我担心它可能会在类别和 id 值不相等的情况下选择产品。如何更正此规则?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。