内容简介:今天在做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。
【备注】我是比较看源码的,多看看源码,还是有好处的。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Introduction to Computation and Programming Using Python
John V. Guttag / The MIT Press / 2013-7 / USD 25.00
This book introduces students with little or no prior programming experience to the art of computational problem solving using Python and various Python libraries, including PyLab. It provides student......一起来看看 《Introduction to Computation and Programming Using Python》 这本书的介绍吧!