Hibernate对象的的三种状态。
Transient :游离态
Persistent :持久化
Detached :托管态
Configuration con = new AnnotationConfiguration(); SessionFactory sf = con.configure().buildSessionFactory(); Session session =null; session =sf.getCurrentSession(); session.beginTransaction(); Teacher t = new Teacher(); t.setName("wsx"); t.setSalary(Salary.a.getValue()); t.setTitle("teacher"); session.save(t); session.getTransaction().commit(); sf.close();
我们先说明三个空间存储区域。
1.内存 2.缓存 3.数据库
当new一个对象的时候,我们的对象只在内存中占用一份空间。而在缓存和数据里面是没有相关映射数据的。
此时的这种状态也就是游离的。也就是transient状态。
当我们执行到save方法的时候,此时。我们新创建的这个对象的相关信息,也就是这个对象本身存储到数据库里面了。而且在缓存里面也是有一份的。
我们这儿对缓存做一些必要的说明:
首先缓存是内存中的一片区域,这片区域。目的是为了提高访问效率。因为每次从数据库里面获取数据是一件非常耗时的事情。这样如果把我们需要的数据临时放到内存里面。那么我们的读取效率将是非常的高。
在此中情况下,我们的缓存其实里面存放的是一个session对象。这个对象里面是一个hashmap。
这个map有一个key和一个value值。key代表 对象的id值。也就是在数据库里面主键的值。就拿上面的例子来说,当我们save之后,再获取对象的id值的时候。我们可以得到此时对象的id值。而在save之前。对象的id是没有值的,而是默认的id=0;value代表对象的引用。这样save之后。我们数据库里面还有缓存session里面以及对象本身都是有id的。而当我们close session之后,那么此时的情况是我们的对象本身和数据库里面都是由id值的。而我们的session里面是没有id的。这是因为session关闭了。对象是和数据库没有关系了的。这样也就是说对象是托管了的。
sessionfactory创建session的两种方法
SessionFactory.openSession 和SessionFactory.getCurrentSession()
前者总是打开,后者是单例实现的。在未提交前不管得到多少当前session都是同一个,一旦提交就会变成一个新的session。
如果是openSession那么每次需要手动的进行关闭close。而如果是CurrentSession。那么我们在每次提交完成后则自动关闭。
<property name="current_session_context_class">thread</property>
如果要是使用CurrentSession的话,那么我们必须要设置上面这行,根据参考。这个里面含有四个值
第一个是jta,第二个是thread,第三个manager,第四个custom.class
后面两个不用,而第一个和第二个我们用的。
Jta是java transaction api 的简称 用于分布式系统的