Query和SQLQuery的区别

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

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

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


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

查看所有标签

猜你喜欢:

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

Spring揭秘

Spring揭秘

王福强 / 人民邮电出版社 / 2009.8 / 99.00元

没有教程似的训导,更多的是说故事般的娓娓道来,本书是作者在多年的工作中积累的第一手Spring框架使用经验的总结,深入剖析了Spring框架各个模块的功能、出现的背景、设计理念和设计原理,揭开了Spring框架的神秘面纱,使你“知其然,更知其所以然”。每部分的扩展篇帮助读者活学活用Spring框架的方方面面,同时可以触类旁通,衍生出新的思路和解决方案。 本书内容全面,论述深刻入理,必将成为每......一起来看看 《Spring揭秘》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具