1. 主要类与接口
Hibernate。Hibernate通过Configuration的实例加载配置文件信息,然后读取指定对象关系映射文件的内容并创建SessionFactory实例。
SessionFactory接口
负责初始化Hibernate。一个SessionFactory实例对应一个数据库。应用程序从SessionFactory中获得Session实例。
Session接口
Session被称为持久化管理器,负责管理与持久化相关的操作:存储、更新、删除和加载对象。
Transaction接口
是Hibernate框架的事务接口。它对底层的事务接口做了封装。包括:JDBC API和JTA。
2. Session的缓存(一级缓存)
Session的CRUD方法以及调用查询接口的list(),iterate()方法时,如果session缓存中不存在相应的对象,Hibernate就会把该对象加入到第一级缓存中,如果session缓存中已经存在这个对象,就不需在去数据库加载,而直接使用缓存中的对象。
flush: 进行清理缓存(此时缓存中的数据并不丢失)的操作,让缓存和数据库同步 执行一些列sql语句,但不提交事务,;
commit:先调用flush() 方法,然后提交事务. 则意味着提交事务意味着对数据库操作永久保存下来。
session的缓存一般交由hibernate框架自动管理。
3. Session的几个主要方法
1)、save保存数据,相当于insert方法
2)、delete,删除对象
3)、update,更新对象,如果数据库中没有记录,会出现异常。
4)、get,根据ID查,会立刻访问数据库。
5)、Load,根据ID查,(返回的是代理,不会立即访问数据库)。
6)、saveOrUpdate (根据ID和version的值来确定是save或update
4.主键id的属性值:取值标示符取值器
注:native:hibernate自动选择底层数据库;
increment:由hibernate管理主键,自动以递增的方式生成标识符,每次增量为1。其在每次插入前取得一个当前最大的id+1作为主键,该主键必须为Integer类型;
sequence:DB2、oracle数据库;
identity:DB2、mysql、sql service数据库;
foregin:外键关联,常和one-to-one一块用
5. 一个运用hibernate写的增删改查例子
自己手动编写的一个工具类 Hibernate.java package com.hbsi.utils; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.cfg.Configuration; public class HibernateUtil { private static Session session; static{ Configuration cfg = new Configuration().configure(); SessionFactory factory = cfg.buildSessionFactory(); session = factory.openSession(); } public static Session getSession(){ return session; } public static void close(){ if(session!=null){ session.close(); } } } 增删改查类 UtilTest.java: package com.hbsi.test; import java.util.Date; import java.util.List; import org.hibernate.Query; import org.hibernate.Session; import org.junit.Test; import com.hbsi.domain.User; import com.hbsi.utils.HibernateUtil; public class UtilTest { @Test public void addUser(){ User user = new User(); user.setName("lisi"); user.setBirthday(new Date()); try{ Session session = HibernateUtil.getSession(); session.beginTransaction(); session.save(user); session.getTransaction().commit(); }catch(Exception e){ e.printStackTrace(); }finally{ HibernateUtil.close(); } } @Test public void deleteUser(){ try{ //方法一:先查找,再操作 /*Session session = HibernateUtil.getSession(); session.beginTransaction(); User user = (User)session.get(User.class, 1); session.delete(user); session.getTransaction().commit();*/ //方法二:直接new出bean类,然后指明要删除的id Session session = HibernateUtil.getSession(); session.beginTransaction(); User user = new User(); user.setId(2); session.delete(user); session.getTransaction().commit(); }catch(Exception e){ e.printStackTrace(); }finally{ HibernateUtil.close(); } } @Test public void updateUser(){ try{ //方法一:先查找,再操作 /*Session session = HibernateUtil.getSession(); session.beginTransaction(); User user = (User)session.get(User.class, 2); user.setName("lisi"); session.update(user); session.getTransaction().commit();*/ //方法二:直接new出bean类,然后指明要更新的id,这种方法适合删除不适合更新,比如你只更新名字字段,其他的字段就会变成空 Session session = HibernateUtil.getSession(); session.beginTransaction(); User user = new User(); user.setId(2); user.setName("利索"); session.update(user); session.getTransaction().commit(); }catch(Exception e){ e.printStackTrace(); }finally{ HibernateUtil.close(); } } //按id查找;get()方法会立刻访问数据库;load()方法返回的是代理,不会立即访问数据库 @Test public void findUser(){ try{ Session session = HibernateUtil.getSession(); User user = (User)session.get(User.class, 1); System.out.println(user.getId()+"----"+user.getName()+"----"+user.getBirthday()); }catch(Exception e){ e.printStackTrace(); }finally{ HibernateUtil.close(); } } //按id查找,懒加载;之所以说懒,是因为这里的load()方法与上面的get()方法有所不同,前者只有在使用load()方法返回的对象时才去执行sql语句,不使用不执行;而后者不一样,它不管什么时候都执行 @Test public void loadUser(){ try{ Session session = HibernateUtil.getSession(); User user = (User)session.load(User.class, 1); System.out.println(user.getId()+"----"+user.getName()+"----"+user.getBirthday()); }catch(Exception e){ e.printStackTrace(); }finally{ HibernateUtil.close(); } } //查找所有 @Test public void findAll(){ try{ Session session = HibernateUtil.getSession(); Query query = session.createQuery("from User"); List<User> list = query.list(); for(User user : list){ System.out.println(user.getId()+"----"+user.getName()+"----"+user.getBirthday()); } }catch(Exception e){ e.printStackTrace(); }finally{ HibernateUtil.close(); } } }