zoukankan      html  css  js  c++  java
  • Hibernate主键生成策略与save()方法是否发sql语句的研究

        public class SessionFlushTest extends TestCase {  
          
        /**
        * 测试uuid主键生成策略
        */  
        public void testSave1() {  
           Session session = null;  
           Transaction tx = null;  
           try {  
            session = HibernateUtils.getSession();  
            tx = session.beginTransaction();  
          
            User1 user = new User1();  
            user.setName("李四");  
            user.setPassword("123");  
            user.setCreateTime(new Date());  
            user.setExpireTime(new Date());  
             
            //因为user的主键生成侧路采用的是uuid,所以调用完成save后,只是将user纳入到了session的管理  
            //不会发出insert语句,但是id已经生成,session中existsInDatebase状态为false  
            session.save(user);  
             
            //调用flush,hibernate会清理缓存,执行sql  
            //如果数据库的隔离级别设置为为提交读,那么我们可以看到flush过的数据  
            //并且session中existsInDatebase状态为true  
            session.flush();  
             
            //提交事务  
            //默认情况下commit操作会先执行flush清理缓存,所以不用显示的调用flush  
            //commit后数据是无法回滚的  
            tx.commit();  
           }catch(Exception e) {  
            e.printStackTrace();  
            tx.rollback();  
           }finally {  
            HibernateUtils.closeSession(session);  
           }  
        }  
          
        /**
        * 测试native主键生成策略
        */  
        public void testSave2() {  
           Session session = null;  
           Transaction tx = null;  
           try {  
            session = HibernateUtils.getSession();  
            tx = session.beginTransaction();  
          
            User2 user = new User2();  
            user.setName("张三1");  
            user.setPassword("123");  
            user.setCreateTime(new Date());  
            user.setExpireTime(new Date());  
             
            //因为user的主键生成策略为native,所以调用session.save后,将执行insert语句,返回有数据库生成的id  
            //纳入了session的管理,修改了session中existsInDatebase状态为true  
            //如果数据库的隔离级别设置为为提交读,那么我们可以看到save过的数据  
            session.save(user);  
            tx.commit();  
           }catch(Exception e) {  
            e.printStackTrace();  
            tx.rollback();  
           }finally {  
            HibernateUtils.closeSession(session);  
           }  
        } 
  • 相关阅读:
    JQuery 简单实现折叠菜单
    机械迷城攻略2
    ffmpeg视频转换及截图
    机械迷城攻略3
    SQL:清空数据库所有数据
    .net发送邮件outlook中文乱码
    我读我的Book
    转:精妙SQL语句收集
    SQL server 动态查询(表名或字段动态),并且获取想得到的返回值结果
    软件开发中,这些文档你用到了吗
  • 原文地址:https://www.cnblogs.com/hainange/p/6153653.html
Copyright © 2011-2022 走看看