Hibernate解决原生SQL映射为对象的问题探究
2016-11-17 16:54
513 查看
如何将使用本地原生SQL查询出来的结果映射为值对象的问题,这里就Hibernate中提供的方法做个结论。前提,这里没有使用属性的延迟加载技术。
假设有个值对像,如下:Java代码
如果查询全部五列记录的话,那么只要:
Java代码:
如果只需要查询id,name,age三列记录呢?那么就要新增构造方法了:
Java代码:
然后,就可以通过HQL来进行查询。
Java代码:
这个方法通常可以满足需要了。但是,如果还需要查询id,name,phone三列记录的话,还需要新增构造方法,不行了,会出现构造方法冲突了。有个办法:
Java代码:
但是,这个只适用于存在Person实体的,如果Hibernate中没有进行Person映射就不可行,如系统中只存在一个JavaBean,可通过下面方法:
Java代码
那么Hibernate就会自动将查出来的三列内容组装到VO对象中去,只是代码量有点大,而且名称都需要重新定义为小写的(需set方法属性一致),在Oracle中查出来的列都默认为大写的(不知道其它数据库怎么样)
这个办法就不依赖于构造方法了,只需要定义私有变量,设置getter/setter方法就行了。
不过如果更猛点的,根本就没有JavaBean对象可以填充怎么办,Hibernate可以将查出来的列组装到集合类中去。如Map。
Java代码:
除了这个Transformers还可以将列转化为List。
到此,还可以通过继承Transformers将结果映射为其它对象,不累述了,基本功能够用了。
假设有个值对像,如下:Java代码
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; } }
如果查询全部五列记录的话,那么只要:
Java代码:
List list = getHibernateTemplate().loadAll(Person.class);
如果只需要查询id,name,age三列记录呢?那么就要新增构造方法了:
Java代码:
public Person(Long id, String name, Long age) { this.id = id; this.name = name; this.age = age; }
然后,就可以通过HQL来进行查询。
Java代码:
List list = getHibernateTemplate().find("select new test.Person(id,name,age) from Person");
这个方法通常可以满足需要了。但是,如果还需要查询id,name,phone三列记录的话,还需要新增构造方法,不行了,会出现构造方法冲突了。有个办法:
Java代码:
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,可通过下面方法:
Java代码
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对象中去,只是代码量有点大,而且名称都需要重新定义为小写的(需set方法属性一致),在Oracle中查出来的列都默认为大写的(不知道其它数据库怎么样)
这个办法就不依赖于构造方法了,只需要定义私有变量,设置getter/setter方法就行了。
不过如果更猛点的,根本就没有JavaBean对象可以填充怎么办,Hibernate可以将查出来的列组装到集合类中去。如Map。
Java代码:
List list = getSession().createSQLQuery("select * from person") .setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
除了这个Transformers还可以将列转化为List。
Java代码 List list = getSession().createSQLQuery("select * from person") .setResultTransformer(Transformers.T0_LIST);
到此,还可以通过继承Transformers将结果映射为其它对象,不累述了,基本功能够用了。
相关文章推荐
- 解决Hibernate原生SQL映射问题 - SQL查询出来的结果映射为值对象
- 解决Hibernate原生SQL映射问题
- 解决Hibernate原生SQL映射问题
- 解决Hibernate原生SQL映射问题
- 使用Hibernate 5.0、4.0、3.0 createSQLQuery执行原生Sql语句 遇到问题及解决办法集锦
- hibernate使用原生sql查询Hibernate原生SQL多表查询字段名重复问题以及解决方法
- hibernate中的sql语句写在xxx.hbm.xml中解决hibernate中原生sql的硬编码问题
- hibernate使用原生的sql,解决管理查询、结果集封装等问题
- Hibernate使用原生SQL多表查询时字段名相同导致查询数据覆盖问题解决办法
- hibernate原生sql查询映射java bean问题,出现Ljava.lang.object错误
- 在使用Hibernate时,因为一个查询需要更多的表连接而要使用SQL来解决性能问题。然而返回的结果集中包含了没有映射的Entity类中的表字段,在这个SQL中还有使用如何将层次关系的父子结点显示为横行
- 问题解决:SqlParameterCollection只接受非空的SqlParameter类型对象,不接受SqlParameter[]对象
- Hibernate 使用 SQL 查询时报错 “对象名 XX 无效”的解决办法
- 处理Hibernate中Pojo对象String属性不能映射Sqlserver2005 text类型字段问题
- json解决hibernate中级联对象延迟加载问题net.sf.json.JSONException: org....
- linq to sql统一更新方法,直接返回更新的对象(解决更新后再刷新数据错误显示问题)
- 问题解决:SqlParameterCollection只接受非空的SqlParameter类型对象,不接受SqlParameter[]对象
- org.hibernate.QueryException: addEntity() or addScalar() must be called on a sql query before executing the qury 问题的解决
- 在hibernate中直接执行原生sql遇到类型转换问题
- 解决字段名带下划线在Hibernate映射问题