课程咨询: 400-996-5531 / 投诉建议: 400-111-8989
认真做教育 专心促就业
昆明达内的小编这一期给大家讲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语句进行查询。
了解详情请登陆昆明达内IT培训官网(km.tedu.cn)!