hibernate 映射自定义对象

本文介绍如何利用Hibernate的createSQLQuery方法结合Transformers.aliasToBean进行自定义VO对象的数据填充,避免依赖构造方法,仅需定义私有变量及getter/setter,特别适用于从数据库查询结果转换至VO对象的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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方法就行了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值