一.事务
Hibernate的任何对数据有改动的操作,都应该被放在事务里面.
hibernate中的事务由s.beginTransaction();开始
//中间是多个操作啊,表类型必须是INNODB
由s.getTransaction().commit();结束
二.延迟加载lazyload
属性延迟加载 当使用load的方式来获取对象的时候
只有访问了这个对象的属性
hibernate才会到数据库中进行查询。
否则不会访问数据库
Product p = (Product)s.load(Product.class, 1);
//还没有访问数据库
System.out.println(p.getName());
//访问属性时才访问数据库
关系延迟加载 在one-many many-many的时可用
修改Category.hbm.xml中的<set name="products" lazy="true">
表示通过Category获取产品是延迟加载的
Category c = (Category) s.get(Category.class, 1);
//只会查询Category表的信息不会查询product_表
System.out.println(c.getProducts());
//通过category取products时才会进行对product_表的查询
三.级联
四种级联
all:所有操作都执行级联操作
none:所有操作都不执行级联操作
delete:删除时执行级联操作
save-update:保存和更新时执行级联操作
1.delete级联
在Category.hbm.xml加上
<set name="products" cascade="delete" lazy="false">
2.save-update级联
<set name="products" cascade="save-update" lazy="false">
四.一级缓存
默认开启,存放在Session上
五.二级缓存
hibernate.cfg.xml 中增加对二级缓存的配置,存放在SessionFactory上
六.使用Criterria进行分页查询
无论使用的是Oracle,Mysql,NoSQL还是DB2,分页查询的代码写法都是一样的
Criteria c= s.createCriteria(Product.class);
c.add(Restrictions.like("name", "%"+name+"%"));
c.setFirstResult(2);//表示从第二条数据开始
c.setMaxResults(5);//表示一共查询5条数据
七.get/load获取方式
是否延迟加载 id不存在对象
load 只有属性被访问时才会调用sql语句 抛出异常
get 无论后面是否访问属性马上执行sql语句 返回null
八.两种获得session方式
openSession 每次得到一个新的session
只有增加删除修改需要事务,查询时不需要
getCurrentSession 在同一个线程每次都是相同的Session
所有操作都放在事务中进行,提交事务后session自动关闭,不能再进行关闭
九.N+1
1,就是指只返回id的SQL语句
N指的是如果在缓存中找不到对应的数据,就到数据库中去查
Hibernate有缓存机制,可以通过用id作为key把product对象保存在缓存中
首先通过Query的iterator把所有满足条件的Product的id查出来
然后再通过it.next()查询每一个对象
如果这个对象在缓存中,就直接从缓存中取了
否则就从数据库中获取
同时hibernate也提供Query的查询方式。
假设数据库中有100条记录,其中有30条记录在缓存中,
但是使用Query的list方法,就会所有的100条数据都从数据库中查询,而无视这30条缓存中的记录
十.查询总数
Query q =s.createQuery("select count(*) from Product p where p.name like ?");
q.setString(0, "%"+name+"%");
long total= (Long) q.uniqueResult();
十一.乐观锁
十二.C3P0连接池