使用createSQLQuery直接封装成自定义对象

在query中加上 setResultTransformer(Transformers.aliasToBean(clazz));

这里的clazz表示的是传入的自定义的bean.class ,这里的bean是自己封装的,不需要有映射文件,如果使用query = getSession().createSQLQuery(sql).addEntity(clazz); 需要bean具有映射文件

query = getSession().createSQLQuery(sql).setResultTransformer(Transformers.aliasToBean(clazz));


当对象的属性类型与查询出来的字段类型不一致时,可以通过addScalar("smallclass_id", StandardBasicTypes.INTEGER)  这个方法进行设置,第一个参数是字段名称,第二个参数是对象的类型,但是,注意:当使用了addScalar时,所有的查询的字段都需要重新设置类型,否则不设置的字段查询出来值为null,例如:

Query query=getCurrent().createSQLQuery(sql).addScalar("smallclass_id", StandardBasicTypes.INTEGER).addScalar("smallclassrights",StandardBasicTypes.INTEGER).setResultTransformer(new AliasToBeanResultTransformer(SmallClass.class));


封装到SmallClass中的属性只有smallclass_id和smallclassrights两个字段是有值的,如果存在第三个属性,则封装到对象中值为null

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值