Query和SQLQuery的区别

栏目: 数据库 · 发布时间: 7年前

内容简介:今天在做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接口,如图所示:

Query和SQLQuery的区别

接口的实现指向它的实现类,或者它子接口的实现类。我们需要调用addEntity(Goods.class)增加商品类的实体类,hibernate的底层通过反射将数据填充到商品类的实例化的对象中的。但是,接口Query本身是没有这个方法的,因而,我们需要使用SQLQuery,而不是Query。

【备注】我是比较看源码的,多看看源码,还是有好处的。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

高中数学公式定律及要点透析

高中数学公式定律及要点透析

牛胜玉 编 / 2011-2 / 9.80元

《PASS绿卡图书:高中数学公式定律及要点透析(人教A版)(必修+选修)(第9次修订)》精选例句:时尚鲜活例句,再现巩固单词;延伸拓展:搭配用法辨析,提升运用能力;真题例句:精选真题例句,紧密联系高考。便于携带:三年教材词汇,方便随时记忆;附赠录音:用耳朵记单词,让学习零空隙。一起来看看 《高中数学公式定律及要点透析》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具