- 浏览: 75174 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
higher141125:
顶,但是word转换成PDF,报错:Exception in ...
通过jacob 把word转pdf ,excel转html,word转html -
junfengcode:
好文,学习了
Apache+tomcat集群 -
木石流云:
能用两个数据库实现数据库共享的集群吗 不然多个tomcat都是 ...
Apache+tomcat集群 -
wdq:
介绍的很详细!的确不错,学习中!
Apache+tomcat集群
在问答里和论坛中,经常看到有人问,怎样将使用本地SQL查询出来的结果映射为值对象的问题,这里就Hibernate中提供的方法做个结论。前提,这里没有使用属性的延迟加载技术。
假设有个值对像,如下:
- package test;
- public class Person {
- private Long id;
- private String name;
- private Long age;
- private Long phone;
- private String address;
- public Person(Long id, String name, Long age, Long phone, String address) {
- this.id = id;
- this.name = name;
- this.age = age;
- this.phone = phone;
- this.address = address;
- }
- public Long getId() {
- return id;
- }
- public void setId(Long id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public Long getAge() {
- return age;
- }
- public void setAge(Long age) {
- this.age = age;
- }
- public Long getPhone() {
- return phone;
- }
- public void setPhone(Long phone) {
- this.phone = phone;
- }
- public String getAddress() {
- return address;
- }
- public void setAddress(String address) {
- this.address = address;
- }
- }
- package test;
- public class Person {
- private Long id;
- private String name;
- private Long age;
- private Long phone;
- private String address;
- public Person(Long id, String name, Long age, Long phone, String address) {
- this.id = id;
- this.name = name;
- this.age = age;
- this.phone = phone;
- this.address = address;
- }
- public Long getId() {
- return id;
- }
- public void setId(Long id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public Long getAge() {
- return age;
- }
- public void setAge(Long age) {
- this.age = age;
- }
- public Long getPhone() {
- return phone;
- }
- public void setPhone(Long phone) {
- this.phone = phone;
- }
- public String getAddress() {
- return address;
- }
- public void setAddress(String address) {
- this.address = address;
- }
- }
package test; public class Person { private Long id; private String name; private Long age; private Long phone; private String address; public Person(Long id, String name, Long age, Long phone, String address) { this.id = id; this.name = name; this.age = age; this.phone = phone; this.address = address; } public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Long getAge() { return age; } public void setAge(Long age) { this.age = age; } public Long getPhone() { return phone; } public void setPhone(Long phone) { this.phone = phone; } public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } } package test; public class Person { private Long id; private String name; private Long age; private Long phone; private String address; public Person(Long id, String name, Long age, Long phone, String address) { this.id = id; this.name = name; this.age = age; this.phone = phone; this.address = address; } public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Long getAge() { return age; } public void setAge(Long age) { this.age = age; } public Long getPhone() { return phone; } public void setPhone(Long phone) { this.phone = phone; } public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } }
如果查询全部五列记录的话,那么只要
- List list = getHibernateTemplate().loadAll(Person.class);
- List list = getHibernateTemplate().loadAll(Person.class);
List list = getHibernateTemplate().loadAll(Person.class); List list = getHibernateTemplate().loadAll(Person.class);
如果只需要查询id,name,age三列记录呢?那么就要新增构造方法了,
- public Person(Long id, String name, Long age) {
- this.id = id;
- this.name = name;
- this.age = age;
- }
- public Person(Long id, String name, Long age) {
- this.id = id;
- this.name = name;
- this.age = age;
- }
public Person(Long id, String name, Long age) { this.id = id; this.name = name; this.age = age; } public Person(Long id, String name, Long age) { this.id = id; this.name = name; this.age = age; }
然后呢,就可以通过HQL来进行查询。
- List list = getHibernateTemplate().find("select new test.Person(id,name,age) from Person");
- List list = getHibernateTemplate().find("select new test.Person(id,name,age) from Person");
List list = getHibernateTemplate().find("select new test.Person(id,name,age) from Person"); List list = getHibernateTemplate().find("select new test.Person(id,name,age) from Person");
这个方法通常可以满足需要了,只是如果,只需要查询id,name,phone三列记录的话,还新增构造方法?不行了,会出现构造方法冲突了。有个办法:
- List list = getSession().createQuery("select id,name,phone from person").addScalar("id",Hibernate.Long).addScalar("name").addScalar("phone",Hibernate.Long).addEntity(Person.class);
- List list = getSession().createQuery("select id,name,phone from person").addScalar("id",Hibernate.Long).addScalar("name").addScalar("phone",Hibernate.Long).addEntity(Person.class);
List list = getSession().createQuery("select id,name,phone from person").addScalar("id",Hibernate.Long).addScalar("name").addScalar("phone",Hibernate.Long).addEntity(Person.class); List list = getSession().createQuery("select id,name,phone from person").addScalar("id",Hibernate.Long).addScalar("name").addScalar("phone",Hibernate.Long).addEntity(Person.class);
但是,这个只适用于存在Person实体的,如果Hibernate中没有进行Person映射的呢,系统中只存在一个JavaBean。
- List list = getSession().createSQLQuery("select id \"id\",name \"name\",phone \"phone\" from person")
- .addScalar("id",Hibernate.Long).addScalar("name").addScalar("phone",Hibernate.Long)
- .setResultTransformer(Transformers.aliasToBean(Person.class)));
- List list = getSession().createSQLQuery("select id \"id\",name \"name\",phone \"phone\" from person")
- .addScalar("id",Hibernate.Long).addScalar("name").addScalar("phone",Hibernate.Long)
- .setResultTransformer(Transformers.aliasToBean(Person.class)));
List list = getSession().createSQLQuery("select id \"id\",name \"name\",phone \"phone\" from person") .addScalar("id",Hibernate.Long).addScalar("name").addScalar("phone",Hibernate.Long) .setResultTransformer(Transformers.aliasToBean(Person.class))); List list = getSession().createSQLQuery("select id \"id\",name \"name\",phone \"phone\" from person") .addScalar("id",Hibernate.Long).addScalar("name").addScalar("phone",Hibernate.Long) .setResultTransformer(Transformers.aliasToBean(Person.class)));
那么Hibernate就会自动将查出来的三列内容组装到VO对象中去,只是代码量有点大,而且名称都需要重新定义为小写的,在Oracle中查出来的列都默认为大写的(不知道其它数据库怎么样)
这个办法就不依赖于构造方法了,只需要定义私有变量,设置getter/setter方法就行了。
不过如果更猛点的,根本就没有JavaBean对象可以填充怎么办,Hibernate可以将查出来的列组装到集合类中去。如Map。
- List list = getSession().createSQLQuery("select * from person")
- .setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
- List list = getSession().createSQLQuery("select * from person")
- .setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
List list = getSession().createSQLQuery("select * from person") .setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); List list = getSession().createSQLQuery("select * from person") .setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
除了这个Transformers还可以将列转化为List。
- List list = getSession().createSQLQuery("select * from person")
- .setResultTransformer(Transformers.T0_LIST);
- List list = getSession().createSQLQuery("select * from person")
- .setResultTransformer(Transformers.T0_LIST);
List list = getSession().createSQLQuery("select * from person") .setResultTransformer(Transformers.T0_LIST); List list = getSession().createSQLQuery("select * from person") .setResultTransformer(Transformers.T0_LIST);
到此,还可以通过继承Transformers将结果映射为其它对象,不累述了,基本功能够用了。
转自:http://zpball.iteye.com/blog/681165#
发表评论
-
sax解析xml
2012-03-16 16:58 932sax方式解析xml的优点: 只要有jdk的 ... -
windows下查看端口命令
2011-04-18 10:43 2777启动apache提示80端口busy被占用。于是查看一看80端 ... -
商业应用中Java浮点数的精确计算及表示
2011-04-08 16:53 792问题提出(1)、浮点数 ... -
java读取纯真数据库
2011-03-25 14:21 982IPEntry.java package test; /* ... -
ckeditor的详细配置
2011-03-03 18:00 1113一、使用方法: 1、在页面<head>中引入ck ... -
myeclipse6 .0 .1 注册码
2011-02-25 23:20 707package test; import java.io.* ... -
list排序中Comparable Comparator的区别
2010-07-26 14:49 1365当需要排序的集合或数组不是单纯的数字型时,通常可以使用Comp ...
相关推荐
hibernate 对象关系映射总结hibernate 对象关系映射总结hibernate 对象关系映射总结
Hibernate对象关系映射一对多 很基础等文档
hibernate核心,一对多,多对多映射讲解,看了就完全搞明白了
关于hibernate映射和查询,使用MySQL,适合初学者的练习
hibernate关联映射详解SSH 多对多,一对多关系对象映射
对象-关系映射—Hibernate 培训 (中文) 目录 一、持久化层-O/R Mapping 二、Hibernate入门 三、Hibernate映射申明(Mapping declaration) 四、持久化对象的状态和生命周期 五、Hibernate查询 六、Hibernate最佳...
本人在厦门邦初培训时候用的ppt 快速入门文档 内容: 建立一对多的关联关系域模型 建立一对多的参照关系的模型 映射一对多关联关系 通过hibernateAPI级联操作关联对象 其它关系的映射:一对一,多对多
关于hibernate对象关系映射的实例,适合初学者,对应关系有一对一,多对一,多对多
在hibernate中,通常配置对象关系映射关系有两种,一种是基于xml的方式,另一种是基于annotation的注解方式,熟话说,萝卜青菜,可有所爱,每个人都有自己喜欢的配置方式,这个是xml配置的例子
ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现,这样开发人员就可以把对数据库的操作转化为对这些对象的操作。Hibernate正是实现了这种思想,达到了方便开发人员以面向对象的思想来实现对...
Hibernate映射集合属性List,用于映射集合属性 List Hibernate 自动生成表 不需sql
hibernate双向一对多关联映射(XML)
NULL 博文链接:https://dreamzhong.iteye.com/blog/1205496
hibernate 一级缓存、 持久化对象状态和转换、 多表映射操作
对象/关系映射 —Hibernate 对象/关系映射 —Hibernate 对象/关系映射 —Hibernate
hibernate中的ORM映射文件通常以.hbm.xml作为后缀。使用这个映射文件不仅易读,而且可以手工修改,也可以通过一些工具来生成映射文档,下文给大家详细的介绍hibernate中的对象关系映射,需要的朋友参考下吧
在研究对象关系映射的时候经常会用到hibernate框架,这里给出了hibernate框架的案例,通过小的案例来展示对象关系映射技术的应用。
第6章 映射对象标识符 6.1 关系数据库按主键区分不同的记录 6.1.1 把主键定义为自动增长标识符类型 6.1.2 从序列(Sequence)中获取自动增长的标识符 6.2 Java语言按内存地址区分不同的对象 6.3 Hibernate用...
开源对象关系映射框架Hibernate知识培训开源对象关系映射框架Hibernate知识培训
在hibernate中,通常配置对象关系映射关系有两种,一种是基于xml的方式,另一种是基于annotation的注解方式,熟话说,萝卜青菜,可有所爱,每个人都有自己喜欢的配置方式,我在试了这两种方式以后,发现使用...