关闭

Hibernate中Session的几个方法的简单说明

标签: hibernateORMSessionSessionFactory面向对象
1316人阅读 评论(0) 收藏 举报
分类:

个人学习整理,如有不足之处,请不吝指教。转载请注明: @CSU-Max


Hibernate对普通JDBC的操作进行了轻量级的封装,使得开发人员可以利用Session对象以面向对象的思想来实现对关系数据库的操作。

一般通过Configuration对象读取相应的配置文件来创建SessionFactory,然后通过SessionFactory对象获取Session对象,获取Session对象之后,我们就可以相关数据的操作了。

下面来介绍一下Session对象的几种方法:

1、Session.save()
Session.save(Object obj):把瞬时状态对象obj加入到Session缓存中,使之成为持久化对象;选用映射文件指定的标识生成ID;当Session缓存被清理时,向数据库发出一条insert语句,在数据库中新增一条与该持久化对象相应的记录。
在执行Session.save(obj)后,Session清理缓存之前,如果obj对象属性被修改,那么最终存入数据库的值将是最后修改后的值,此过程中ID不能被修改。
//新增一个用户对象 
public void addUser(User user) {
        Session session = HibernateUtil. currentSession ();
        Transaction ts = null ;
        try {
            ts = session.beginTransaction();
            session.save(user);
            ts.commit();
        } catch (Exception e){
            ts.rollback();
            System. out .println( "---error---" );
            e.printStackTrace();
        } finally {
            HibernateUtil. closeSession ();
        }
    }

2、Session.delete()
使用delete()方法删除数据。如果传入的参数是持久化对象,Session就计划执行一个delete语句。如果传入的参数是游离态对象,就会是游离态对象被Session关联,使它变为持久化对象,然后计划执行一个delete语句。
Session只有在清理缓存的时候才执行delete语句;只有当调用Session的close()方法是,才会从Session的缓存中删除该对象。
public void removeUser() {
        Session session = HibernateUtil. currentSession ();
        Transaction ts = null ;
        User user = null ;
        try {
            ts = session.beginTransaction();
            user = (User)session.get(User. class , new Integer( 1 )); //加载一个持久化对象
            session.delete(user); //计划执行一个deleted操作
            ts.commit(); //在清理缓存时,数据库执行deleted操作
        } catch (Exception e){
            ts.rollback();
            System. out .println( "---error---" );
            e.printStackTrace();
        } finally {
            HibernateUtil. closeSession (); //从缓存中删除User对象,关闭Session
        }
    }


        Session session = HibernateUtil. currentSession ();
        Transaction ts = null ;
        try {
            ts = session.beginTransaction();
            /**
            * 假设user是一个游离态对象,调用session.delete(user)会使其先变为 一个持久化对象,然后再计划执行一个deleted操作
            */
            session.delete( user );
            ts.commit(); //在清理缓存时,数据库执行deleted操作
        } catch (Exception e){
            ts.rollback();
            System. out .println( "---error---" );
            e.printStackTrace();
        } finally {
            HibernateUtil. closeSession (); //从缓存中删除User对象,关闭Session
    }


3、Session.get()
如果不确定数据库中是否有匹配的记录存在,即可使用get()方法加载对象,使用get()方法会立刻访问数据库,如果数据库中不存在匹配的记录,则会返回null。
//使用get()方法加载一个指定id的User对象 
public   void  getUserById( int  id) {
        Session session = HibernateUtil. currentSession ();
        Transaction ts =  null ;
        User  user  =  null ;
         try {
            ts = session.beginTransaction();
            user = (User)session.get(User. class , id);
            ts.commit();
        } catch (Exception e){
            ts.rollback();
            System. out .println( "---error---" );
            e.printStackTrace();
        } finally {
            HibernateUtil. closeSession ();
        }   
  }

4、Session.load()
load()方法返回对象的代理,只有在返回对象被调用是Hibernate才会发出SQL语句查询对象。如果指定的记录不存在,则会抛出异常,这个与get()方法是不同的。
//使用load()方法加载一个指定id的User对象 
public   void  getUserById( int  id) {
        Session session = HibernateUtil. currentSession ();
        Transaction ts =  null ;
        User  user  =  null ;
         try {
            ts = session.beginTransaction();
            user = (User)session. load (User. class , id);
            ts.commit();
        } catch (Exception e){
            ts.rollback();
            System. out .println( "---error---" );
            e.printStackTrace();
        } finally {
            HibernateUtil. closeSession ();
        }   
  }

可以自己实验一下,看一下控制台Hibernate的SQL语句输出情况,理解体会其中的不同。


前一段先到这,后面在下次在补充。

5、Session.update()

6、Session.beginTrasaction()

7、Session.close()

8、Session.connection()

9、Session.saveOrUpdate()









0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:64065次
    • 积分:1102
    • 等级:
    • 排名:千里之外
    • 原创:36篇
    • 转载:17篇
    • 译文:0篇
    • 评论:26条
    联系我
    最新评论