Hibernate入门(3)
2010-09-17 10:18
246 查看
(1)配置文件中多次映射同一个类
需要指定 entity name 来区别不同映射实体的对象实例
<class name="Contract" table="Contracts" entity-name="CurrentContract">
</class>
<class name="Contract" table="ContractHistory" entity-name="HistoricalContract">
</class>
(2)集合类映射
映射集合类的 Hibernate 映射元素取决于接口的类型
如:<set> 元素用来映射 Set 类型的属性。
除了 <set>,还有<list>,<map>,<bag>,<array> 和 <primitive-array> 映射元素。
操纵持久化对象
(3)Session缓存的作用:
减少数据库的访问频率,缓存中的对象与数据库中的记录保持同步
Session中commit()和flush()方法的区别:
flush方法进行清理缓存操作,执行一系列sql语句,但不会提交事务
commit方法会先调用flush方法,然后提交事务,将操作保存到数据中。
(4)java对象的状态
-1-临时状态:被new出来,但session并没有执行持久化(save...)方法,不存在缓存中
-2-持久化状态:执行了持久化(save...),存储在session缓存中
-3-游离状态:session关闭或者事务提交,不存在session的缓存中
(5)对象查询
Query对象也有类似JDBC(PreparedStatement)操作的?号设置,不过这里设置的位置是从0位置开始的,而
JDBC是从1开始的
还可以传递一个集合:-------------------------------------------------------------------
List names = new ArrayList();
names.add("Izi");
names.add("Fritz");
Query q = sess.createQuery("from DomesticCat cat where cat.name in (:namesList)");
q.setParameterList("namesList", names);
--------------------------------------------------------------------------------------
分页(查询指定位置的记录):
Query q = sess.createQuery("from DomesticCat cat");
q.setFirstResult(20);
q.setMaxResults(10);
List l = q.list();
需要指定 entity name 来区别不同映射实体的对象实例
<class name="Contract" table="Contracts" entity-name="CurrentContract">
</class>
<class name="Contract" table="ContractHistory" entity-name="HistoricalContract">
</class>
(2)集合类映射
映射集合类的 Hibernate 映射元素取决于接口的类型
如:<set> 元素用来映射 Set 类型的属性。
除了 <set>,还有<list>,<map>,<bag>,<array> 和 <primitive-array> 映射元素。
操纵持久化对象
(3)Session缓存的作用:
减少数据库的访问频率,缓存中的对象与数据库中的记录保持同步
Session中commit()和flush()方法的区别:
flush方法进行清理缓存操作,执行一系列sql语句,但不会提交事务
commit方法会先调用flush方法,然后提交事务,将操作保存到数据中。
(4)java对象的状态
-1-临时状态:被new出来,但session并没有执行持久化(save...)方法,不存在缓存中
-2-持久化状态:执行了持久化(save...),存储在session缓存中
-3-游离状态:session关闭或者事务提交,不存在session的缓存中
(5)对象查询
Query对象也有类似JDBC(PreparedStatement)操作的?号设置,不过这里设置的位置是从0位置开始的,而
JDBC是从1开始的
还可以传递一个集合:-------------------------------------------------------------------
List names = new ArrayList();
names.add("Izi");
names.add("Fritz");
Query q = sess.createQuery("from DomesticCat cat where cat.name in (:namesList)");
q.setParameterList("namesList", names);
--------------------------------------------------------------------------------------
分页(查询指定位置的记录):
Query q = sess.createQuery("from DomesticCat cat");
q.setFirstResult(20);
q.setMaxResults(10);
List l = q.list();
相关文章推荐
- hibernate框架的入门
- Hibernate入门09_QBC及SQL查询
- Structs+Spring+Hibernate快速入门
- Struts+Spring+Hibernate快速入门2(转)
- Hibernate+Junit-史上最详细图解教程-从环境配置到入门
- Structs+Spring+Hibernate快速入门
- 一个简单的Struts Hibernate入门例子(下)
- hibernate入门--->张国亮总结第二季
- Hibernate快速入门—新手Hibernate详细配置步骤介绍
- Hibernate 用annotation写一个入门程序
- 心得3-hibernate入门3
- hibernate入门
- Hibernate入门
- Hibernate学习笔记(一)——简单的Hibernate实例入门
- struts+hibernate+spring一个入门的实用例子
- Hibernate框架第一天(入门)
- Hibernate快速入门
- 《Java从入门到放弃》框架入门篇:hibernate基本配置
- Hibernate入门:关联规则之多对一和一对多
- hibernate入门小例子