@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。
【备注】我是比较看源码的,多看看源码,还是有好处的。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。