【发布时间】:2015-01-19 07:17:07
【问题描述】:
@Transactional //Spring transactional
void saveFile(ExcelFile file) {
//Each sheet have different kind of entities and it is an ordered insert and first insert is needed before the second set of inserts
for(each sheet in excel file) {
List<Entity> entityList = convertIntoEntities(sheet);
ValidationResult vr = validateEntities(entityList);
saveEntities(entityList);
}
ValidationResult validateEntities(List<Entity> entityList) {
validator.validate(entityList) // The new validation we need to do before
}
void saveEntities(List<Entity> entityList) {
dao.saveEntities(entityList);
}
这里的实体列表是在读取一个 excel 文件后形成的,我们正在添加一个验证 excel 文件的逻辑。我们不能只验证 Excel 本身,我们需要在验证之前读取现有的数据库条目。
现在验证器验证我们需要查看数据库中现有实体(其他表的)的 excel(它不是外部约束,存在一些业务逻辑),并为每个无效实体创建一个 validationErrorMessages 列表.
Validation类的结构是
ValidationResult {
boolean isValid;
List<String> errorMessage;
}
我想到了两个解决方案
更改保存的签名并发送 ValidationResult(或将其包装到另一个类中)。在这种情况下,我们需要自己管理回滚,因为当我们不抛出异常时,@Transactional 不会回滚
抛出 InvalidInputFileException,它确实有验证结果。 (我们要存储 ValidationResult 的原因需要通知用户验证失败)。
我赞成这种方法,因为对于不一致的数据抛出异常是正确的,其次@Transactional 可以正常工作,我们不需要管理事务。 但是我之前没有在代码中看到异常类中的成员变量,这样做可以吗?
现在我想到的一种方法是在 ValidationFailure 它抛出的情况下
class InvalidInputFileException extends RuntimeException {
ValidationResult vr;
}
【问题讨论】:
-
那么你的问题是什么?
标签: java validation exception transactional