gpt4 book ai didi

java - 如何使用 Hibernate Validator 来验证表中多行的日期范围?

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:33:37 25 4
gpt4 key购买 nike

我有一个自定义 validator ,我用它来确保在保存实体之前将某些业务规则应用于实体。

例如(假设的),当保存下面定义的 ProductPrice 时,我验证给定产品(由 productId 标识)的 fromDate 和 endDate 与现有 没有重叠数据库中该产品的 code>ProductPrice 行。

@MyCustomValidator
class ProductPrice {

Long productId;

Date fromDate;
Date toDate;
}

只要将 ProductPrice 保存为单个实体,这就可以正常工作。一旦该实体被添加为另一个实体中的一对多关系,如下所示,

class Product {
List<ProductPrice> productPrices;
}

当更新父(Product)实体(为了保存它工作正常),以及子实体(列表中的一个或多个 ProductPrice)的一些更改时,它会失败,因为保存 ProductPrice 的一个实例List 对接下来要保存的 ProductPrice 一无所知。

详细解释:

假设给定的 Product 在数据库中有两个 ProducePrice 行,如下所示:

Id    Product Id        From Date        To Date        Price
1 PRD-001 01-01-2016 10-06-106 29.99
2 PRD-001 11-06-2016 10-12-106 32.99

假设我想将作为 Product 实体一部分的行 (ProductPrice) 更新为以下值:

Id    Product Id        From Date        To Date        Price
1 PRD-001 01-01-2016 30-06-106 29.99
2 PRD-001 01-07-2016 31-12-106 32.99

以上数据仍然有效,但是hibernate validator 会失败。这是因为在保存第一行时,如果我查询数据库以检查现有行的 fromDatetoDate,那么它将与数据库中现有的第二行重叠。但这是不正确的,因为第二行也将被更新为有效值。也有可能,表中有 3 行,而我在当前事务中只更新了其中的 2 行,第 3 行未被触及。因此,我必须在 validator 中查询数据库以检查有效性,这一点很重要。

问题太长了,我可能没把问题说清楚。但是总结一下,是否可以查询当前的持久化上下文,得到脏数据(即将保存)?

最佳答案

它可以工作,但我不确定它的最佳效果如何,这取决于您的上下文。

但想法是,当您查询数据库以检查现有行的 fromDate 和 toDate 时,您还应该查询您将从中更新数据库的集合,并基于它来更新 fromDate 和 toDate,在这种情况下将是有效:)

关于java - 如何使用 Hibernate Validator 来验证表中多行的日期范围?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45139241/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com