我正在使用JBoss 6和Seam,我有一个我试图坚持的实体,User
。我扩展了org.jboss.seam.framework.EntityHome
以提供UserHome
类并且已经覆盖了persist()
方法。我用javax.validation注释彻底注释了我的实体类。当我为实体类中的所有字段提供有效值时,该对象将保持不变。当我违反其中一个验证约束时,持久性会按预期失败。
我遇到的问题是在异步持久化期间违反约束:hibernate没有告诉我哪个约束被违反了!
javax.validation.ConstraintViolationException: validation failed for classes [com.example.model.User] duringpersist time for groups [javax.validation.groups.Default, ]
at org.hibernate.cfg.beanvalidation.BeanValidationEventListener.validate(BeanValidationEventListener.java:132)
at org.hibernate.cfg.beanvalidation.BeanValidationEventListener.onPreInsert(BeanValidationEventListener.java:71)
如果我通过将EntityManager.flush()
添加到UserHome.persist()
强制同步持久性,那么我可以捕获包含违反约束的ConstraintViolationException
和输出日志语句。
我的问题:是否可以使用hibernate / jboss注册一个监听器来进行约束违规?我认为hibernate没有打印违规行为有点蹩脚,但希望我可以插入一些代码来捕获并记录它们以获取更多信息。否则我不知道违反了什么约束。
谢谢!