一
:概念模型---〉关系数据模型--〉域模型
域对象之间的关系 :
1 :关联(Association)
2:依赖 (Dependency)
3:聚集 (Aggregation)
4 :一般化 (Generalization)
二 :SessionFactory接口 与 Session 接口
SessionFactory 接口特点 :
1 :他是线程安全的,它的同一个实例可以被应用的多个线程共享。
2 :他是重量级的,意味着不能随意创建和销毁它的实例,它需要一个很大的缓存,用来存放预定义的SQL语句以及映射元数据等
3 :用户还可以为SessionFactory配置一个缓存插件,该插件被称为Hibernate的第二级缓存,该缓存用来存放被工作单元读过的数据,将来其它工作单元可能会重用这些数据,一个工作单元对应一个数据库事务。
Session接口 特点 :
1 :不是线程安全的,应该避免多个线程共享同一个session实例。
2 : Session实例是轻量级的,它的创建和销毁不需要消耗太多资源。
3 : Session有一个缓存,被称为Hibernate的第一级缓存,每个Session实例都有自己的缓存。处于缓存中的对象处于持久化状态,它和数据库中的相关记录对应,Session能够在某些时间点,按照缓存中持久化对象的属性变化来同步更新数据库,这个过程被称为清理缓存。
三 :cascade用法
<many-to-one
name="customer"
column="CUSTOMER_ID"
class="mypack.Customer"
cascade="save-update"
not-null="true" />
当cascade属性为 "save-update",默认是 "none"
,表明保存或更新当前对象时(即执行insert或update语句时)会级联保存或更新与它关联的对象。
当一个持久化对象,引用一个临时对象时(有时候是添加,有时候是在flush时)会发生异常。
cascade="all|none|save-update|delete|all-delete-orphan"
四 :Java 集合 (如 Set,List和Map)的一个重要特征是 :集合中存放的是Java对象的引用,当向集合中添加一个对象时,其实是把这个对象的引用添加到集合中。
五 :批量更新
1 :最耗资源的方式 :执行壹万句update操作
tx = session.beginTransaction();
Iterator customers = session.find("from Customer c where c.age>0").iterator();
while(customers.hasNext()){
Customer customer = (Customer)customers.next();
customer.setAge(customer.getAge()+1);
}
tx.commit();
session.close();
2 :稍微好一点,释放了一级缓存中的资源,但仍 1万句update数据库操作。
tx = session.beginTransaction();
Iterator customers = session.find("from Customer c where c.age>0").iterator();
while(customers.hasNext()){
Customer customer = (Customer)customers.next();
customer.setAge(customer.getAge()+1);
session.flush();
session.evict(customer);
}
tx.commit();
session.close();
3 :绕过hibernate API 直接通过JDBC API来执行该SQL语句
tx = session.beginTransaction();
Connection con = session.connection();
PreparedStatement stmt = con.prepareStatement("update Custormers set age= age+1 where age>0");
stmt.executeUpdate();
tx.commit();
|