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为止,才可以获取到底层的异常。如:
- 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);
- }
0 0
- hibernate unique配置 和 异常的捕获
- hibernate unique配置 和 异常的捕获
- hibernate的unique配置
- unique constraint异常捕获
- hibernate 捕获低层的异常
- 异常的捕获和处理
- 异常的捕获和处理
- 异常的捕获和处理
- 异常的捕获和处理
- 抛出异常和捕获异常的区别
- 抛出异常和捕获异常的区别
- tp5中捕获异常的配置
- js 异常的捕获和使用
- 未捕获和意外的异常处理
- Java异常的捕获和抛出
- Python异常信息的捕获和处理
- 抛出异常和捕获异常
- 子类异常和父类异常捕获的关系
- 利用.dSYM和.app文件准确定位Crash位置
- libGDX视频教程(九) -- 演员类(二)
- 半链接改写成关联
- 弹出新ViewController的方法
- Unable to execute dex: java.nio.BufferOverflowException.解决办法
- hibernate unique配置 和 异常的捕获
- Android paint字体的使用
- 对ms10-087(CVE-2010-3333)漏洞分析
- X001: selenium2.0关于python的常用函数
- memcached单点故障与负载均衡
- shell 小括号中括号大括号
- 在游戏中使用“CEGUI” — 第一章(底层)
- 通过驱动使应用程序直接操作IO口,通过端口终止PC喇叭发声
- Unicode 字符全集