共计 842 个字符,预计需要花费 3 分钟才能阅读完成。
@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。
【备注】我是比较看源码的,多看看源码,还是有好处的。