内容简介:今天在做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。
【备注】我是比较看源码的,多看看源码,还是有好处的。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。