内容简介:今天在做dao层操作时,一不小心写错了,得到两种情况,一种是 query=getSession().createSQLQuery(sql).addEntity(Goods.class);和query=getSession().createQuery(sql)。也是可以的,为什么能这样呢?查看hibernate底层源码时发现,SQLQuery继承Query接口,如图所示:
@Override
public Goods checkGoods(Long categoryId, Long tenantId, String cardNo) {
String sql = "SELECT " +
" * " +
"FROM " +
" cce_goods " +
"WHERE " +
" is_deleted = 0 " +
" AND goods_category_id = '" + categoryId + "' " +
" AND commercial_tenant_id ='" + tenantId + "' " +
" AND card_no = '" + cardNo + "'";
Query query =null;
query=getSession().createSQLQuery(sql).addEntity(Goods.class);
query.setParameter("0",1);
query.setResultTransformer(Transformers.aliasToBean(Goods.class));
query=getSession().createQuery(sql);
return (Goods) query.uniqueResult();
}
今天在做dao层操作时,一不小心写错了,得到两种情况,一种是 query=getSession().createSQLQuery(sql).addEntity(Goods.class);和query=getSession().createQuery(sql)。也是可以的,为什么能这样呢?
查看hibernate底层源码时发现,SQLQuery继承Query接口,如图所示:
接口的实现指向它的实现类,或者它子接口的实现类。我们需要调用addEntity(Goods.class)增加商品类的实体类,hibernate的底层通过反射将数据填充到商品类的实例化的对象中的。但是,接口Query本身是没有这个方法的,因而,我们需要使用SQLQuery,而不是Query。
【备注】我是比较看源码的,多看看源码,还是有好处的。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Learning PHP & MySQL中文版
车立红 / 中国电力出版社 / 2007-06 / 36.00元
《Learning PHP & MySQL中文版》将介绍程序、模板和数据库的工作原理,讲述如何应对其中的挑战,并彻底地探索这些技术。一起来看看 《Learning PHP & MySQL中文版》 这本书的介绍吧!