疯狂java


您现在的位置: 疯狂软件 >> 新闻资讯 >> 正文

Hibernate中的常用API


 

 
1.Configuration
 
  1.1 加载核心配置文件,
 
  加载hibernate.properties时:Configuration configuration = new Configuration();
 
  加载hibernate.cfg.xml时:Configuration configuration = new Configuration().configure();
 
  1.2  加载映射文件(不过,一般映射文件都配置在核心配置文件中,该方法用少)
 
  configuration.addResource("com/itheima/hibernate/domain/Customer.hbm.xml");
 
  configuration.addClass(Customer.class);//实体类必须和映射文件在同一个包中才行
 
2.SessionFactory
 
  SessionFactory负责管理Session,管理连接池,管理Hibernate二级缓存。是一个重量级的, 线程安全的对象.
 
3.session
 
  Session是Hibernate程序与数据库之间的桥梁。完成CRUD的操作。Session是一个单线程的对象,内部维护了Hibernate的一级缓存。
 
hibernate的一级缓存--->session级别的缓存
 
  一级缓存是session级别的缓存, 同session的声明周期一直. 一级缓存实际上是由session中的一组集合构成的.
 
  一级缓存的主要作用: 减少对数据库的访问次数
 
  执行原理: 在session中执行查询操作时,首先会从缓存中获取结果, 如果缓存中没有, 则去数据库中查询, 并将查询结果往缓存中存放一份; 如果缓存中有, 则直接从缓存中获取.
 
  一级缓存快照区: 在存放在缓存中的数据会在session一级缓存的快照区存放一份, 当数据发生变更时, 缓存中的数据会被修改, 而快照区的数据还是原来的数据, 在事务提交时, 会对比一级缓存和快照区, 如果数据不一致, 则会发送sql语句更改数据库中数据; 如果数据一致,  则不对数据库进行更新操作. 因此, 对于持久态的对象,  即使没有显示的添加update语句, 如果数据发生变化, 在提交事务时, 会自动更新数据库.
 
 
 
  session保存一个对象: session.save(entity);
 
  session修改对象:session.update(entity);
 
  session删除对象session.delete(entity);
 
  session查询对象:session.get()和session.load();
 
get()方法和load()方法的区别
 
  1.   加载机制不同. get方法采用的是立即加载,执行到代码的时候,立即发送SQL语句进行查询;  而load方法采用的延迟加载(Lazy)机制, 执行该代码的  时候不会马上发送SQL语句,只有真正使用该对象的时候才会发送SQL语句查询.
 
  2.    查询结果不同. get方法查询得到的是对象本生,  而load方法查询返回的一个代理对象;
 
  3.      查询没有找到时的处理应答不同, get方法返回的是null;  而load方法则会抛出异常ObjectNotFoundException;
4. Query:支持HQL查询
 
获得Query接口可以通过session.createQuery(String hql);获得。
 
HQL:Hibernate Query Language。Hibernate查询语言。语法与SQL是类似的。HQL中查询的是对象。
 
public void demo2(){
 
  //HibernateUtils为编写的获取创建sessionFactory和获取session的工具类
 
        Session session = HibernateUtils.getCurrentSession();
 
        Transaction tx = session.beginTransaction();
 
        // HQL的基本查询
 
        Query query = session.createQuery("from Customer");
 
        List<Customer> list = query.list();
 
       
 
        for (Customer customer : list) {
 
           System.out.println(customer);
 
        }
 
       
 
        tx.commit();
 
    }
 
5.Criteria:支持QBC查询
 
获得Criteria接口可以通过session.createCriteria();获得。
 
QBC:Query By Criteria。条件查询。一种更加面向对象的方式.
 
  统计查询
 
      Criteria criteria = session.createCriteria(Customer.class);
 
      criteria.setProjection(Projections.rowCount());
 
                 Long count = (Long) criteria.uniqueResult();
 
5.1 离线条件查询 DetachedCriteria.
 
   DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Customer.class);
 
        detachedCriteria.add(Restrictions.like("cust_name", "%强%"));
 
       
 
        Session session = HibernateUtils.getCurrentSession();
 
        Transaction tx = session.beginTransaction();
 
       
 
        Criteria criteria = detachedCriteria.getExecutableCriteria(session);
 
        List<Customer> list = criteria.list();
 
        for (Customer customer : list) {
 
           System.out.println(customer);
 
        }
 
        tx.commit();
 
    }
 
 
 
6.SQLQuery:支持SQL查询
 
获得SQLQuery接口可以通过session.createSQLQuery();获得。
 
SQLQuery:通过SQL语句进行查询。