hibernate第四天

extra策略:
与 lazy=“true” 类似. 主要区别是增强延迟检索策略能进一步延迟 Customer 对象的 orders 集合代理实例的初始化时机:
• 当程序第一次访问 orders 属性的 iterator() 方法时, 会导致 orders 集合代理类实例的初始化
• 当程序第一次访问 order 属性的 size(), contains() 和 isEmpty() 方法时, Hibernate 不会初始化 orders 集合类的实例, 仅通过特定的 select 语句查询必要的信息, 不会检索所有的 Order 对象


----------------------

懒加载:
也叫延迟加载,不是在执行获取操作时马上生成SQL,而是在第一次使用时生成SQL。
分成两种:
类级别的:
<class ... lazy="true/false">
属性级别的:
<set/list/map/bag ... lazy="...">
<many-to-one ... lazy="...">
<one-to-one ... lazy="...">
在使用懒加载特性时,可能会有LazyInitializationException异常:
原因:
真正的去获取数据时,Session已经没有了。
解决办法:
方式一:让Session在真正加载后再关闭。
方式二:或是在Sessoin关闭前执行Hibernate.initialize(department.getEmployees());

HashMap Hashtable

不管是一级缓存,还是二级缓存,都地在使用OID的获取对象时才有效。
get()
load()
对于Query.list()默认不会使用缓存,哪怕写成where id=1也不会使用缓存。

Update \____ 不会通知Session缓存。
Delete / 通知二级缓存

// ==============================================


class TxFilter implements Filter{

puboic void doFilter(request, response, chain){
session = sf.openSession();
Utils.threadLocal.set(session); // 绑定到当前线程上
try{
tx = session.beginTransaction();
chain.doFitler(); // 放行
tx.commit();
}catch(e){
tx.rollback();
throw e;
}finallay{
session.close();
Utils.threadLocal.remove(); // 移除
}

}

}


class UserDao{

public void saveUser(User user){
session = Utils.threadLocal.get();
session.save(user);
}
}

// ==============================================

class TxFilter增强 implements Filter{

puboic void doFilter(request, response, chain){
session = sf.getCurrentSession();
try{
tx = session.beginTransaction();
chain.doFitler(); // 放行
tx.commit();
}catch(e){
tx.rollback();
throw e;
}

}
}

class UserDao增强{

public void saveUser(User user){
session = sessionFactory.getCurrentSession();
session.save(user);
}
}

原文地址:https://www.cnblogs.com/mxf97826/p/8708135.html