`

hibernate unique配置不起作用解决方法

 
阅读更多

hibernate unique配置

    昨天自己创建了表,通过hibernate进行映射,添加了unique的限制,运行JUnit测试的时候发现,hibernate没有对配置的字段没有进行唯一性检查,而是直接通过,存入数据库。让人百思不得其解!
    后来查阅hibernate文档和网上核对,发现unique只在表是由hibernate自己创建的时候才有效,也就是说

  • validate                加载hibernate时,验证创建数据库表结构
  • create                  每次加载hibernate,重新创建数据库表结构
  • create-drop        加载hibernate时创建,退出是删除表结构
  • update                 加载hibernate自动更新数据库结构

hibernate.hbm2ddl.auto=update或create或create-drop时 如果数据库中没有表,那么hibernate创建表的时候就会在配置的字段上加上唯一约束。
hibernate.hbm2ddl.auto=update时 如果数据库中有表,hibernate并不会检测配置的字段是否有唯一约束,只要其他配置相同,就不会更新,所以此时的表没有唯一约束。
总之:如果要使用unique约束,那么表需要由hibernate生成 或者自己在表中添加约束,所以对于字段的唯一性约束,都是在数据库端做检查的

另:hibernate-release-4.2.0.final版本好像有问题,升级到4.2.5之后就解决了!

hibernate 异常捕获

在做测试的时候,在添加了唯一性约束的表中,插入重复数据,数据库报“ORA-00001: 违反唯一约束条件 (oracle用户名.oracle约束名称)”,原本想在action层获取异常信息的,通过JDBCException和HibernateException都无法捕获到异常,通过RuntimeException和Exception才可以捕获到异常,但是捕获到的异常通过e.getLocalizedMessage()调用,只有显示“Could not execute JDBC batch update; nested exception is org.hibernate.exception.ConstraintViolationException: Could not execute JDBC batch update”,却没有数据库底层的异常。或通过查询文档发现,如果要获取底层的异常,需要通过e.getCause()递归获取,直到e.getCause()==null为止,才可以获取到底层的异常。
如:

 

 

 

catch (RuntimeException e) {
new DaoTest() {
		private void showTraces(Throwable t) {
		Throwable next = t.getCause();
		if (next == null) {
				System.out.println(t.getMessage());
			} else {
				showTraces(next);
			}
		}
	}.showTraces(e);
}

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics