Query和SQLQuery的区别

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

内容简介:今天在做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。

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


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

查看所有标签

猜你喜欢:

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

信息简史

信息简史

[美] 詹姆斯·格雷克 / 高博 / 人民邮电出版社 / 2013-10 / 69.00元

人类与信息遭遇的历史由来已久。詹姆斯•格雷克笔下的这段历史出人意料地从非洲的鼓语讲起(第1章)。非洲土著部落在尚未直接跨越到移动电话之前,曾用鼓声来传递讯息,但他们是如何做到的呢?后续章节进而讲述了这段历史上几个影响深远的关键事件,包括文字的发明(第2章)、罗伯特•考德里的第一本英语词典(第3章)、查尔斯•巴贝奇的差分机与爱达•拜伦的程序(第4章)、沙普兄弟的信号塔与摩尔斯电码(第5章)。 ......一起来看看 《信息简史》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具