hibernate unique配置 和 异常的捕获

来源:互联网 发布:java gui编程教程 编辑:程序博客网 时间:2024/04/30 05:25

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 异常捕获

在做测试的时候,在添加了唯一性约束的表中,插入重复数据,数据库报“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为止,才可以获取到底层的异常。
如:

[java] view plaincopy
  1. catch (RuntimeException e) {  
  2. new DaoTest() {  
  3.         private void showTraces(Throwable t) {  
  4.         Throwable next = t.getCause();  
  5.         if (next == null) {  
  6.                 System.out.println(t.getMessage());  
  7.             } else {  
  8.                 showTraces(next);  
  9.             }  
  10.         }  
  11.     }.showTraces(e);  
  12. }  

0 0
原创粉丝点击