`
luochaobin
  • 浏览: 12947 次
  • 性别: Icon_minigender_1
  • 来自: 昆明
社区版块
存档分类
最新评论

hibernate查询方法总结

阅读更多

 

1.采用 Criteria 类来查询

eg:

  public StoreOrderConsume getByCode(String consumeCode){
      Criteria criteria = this.getSessionFactory().getCurrentSession().
createCriteria(StoreOrderConsume.class);
      criteria.add(Restrictions.eq("consumerCode", consumeCode));
      @SuppressWarnings("unchecked")
List<StoreOrderConsume> storeOrderConsumes = criteria.list();
      if(!CollectionUtils.isEmpty(storeOrderConsumes)){
         return storeOrderConsumes.get(0);
      }
      return null;
  }

   2.采用  Query查询

    2.1 hql 语句查询

 eg:

public List<StoreOrderConsume> getList() {
   String sql = " FROM StoreOrderConsume WHERE num >1";
   Query query = this.getHibernateTemplate().getSessionFactory().getCurrentSession()
.createQuery(sql.toString());
   return ( List<StoreOrderConsume>) query.list();
}

2.2 茶用 sql语句查询

eg:

@Override
public Integer getConsumerCountByOrderPrdId(Integer orderPrdId) {
   String sql = "  SELECT COUNT(id)  FROM store_order_consume WHERE STATUS=0 
AND order_prd_id= "+ orderPrdId;
   Query query = this.getHibernateTemplate().getSessionFactory().getCurrentSession()
.createSQLQuery(sql.toString());
   return Integer.parseInt(query.list().get(0)+"");
}

采用hql语句和sql语句区别在于 createSQLQuery    是否有SQL.SQL.

 

3.hibernate 查询参数返回封装

 3.1采用 Transformers来转换实体

eg:

(List<ConsumeListVo>) query.setResultTransformer(Transformers.aliasToBean(ConsumeListVo.class))
.list());

 

3.2 单个字段转换 采用 addScalar 方法   

@Override
public List<String> getConsumeBuyerMobile() {
   String sql = "SELECT DISTINCT o.buyer_mobile AS buyerMobile FROM store_order o,store_order_prd p " +
         "WHERE o.id=p.order_id AND o.order_type =1 AND  p.order_status = 2 AND " +
         "TIMESTAMPDIFF(MONTH,o.pay_time,NOW()) >1 ";
Query query = this.getHibernateTemplate().getSessionFactory().getCurrentSession().createSQLQuery(sql.toString())
         .addScalar("buyerMobile", StringType.INSTANCE);
List <String> list = query.list();
   return list;
}

 

4.hibernate 的分页查询

query.setFirstResult((orderListMessDo.getPageNum()-1)*orderListMessDo.getPageSize());
query.setMaxResults(orderListMessDo.getPageSize());

5.带入参数 使用 query.setParameter

public int updateDeliverTime(Integer orderId) throws Exception {
    String sql = "UPDATE store_order SET remind_time=NOW() WHERE status=1 AND id=:orderId";
Query query = this.getHibernateTemplate().getSessionFactory().getCurrentSession().createSQLQuery(sql.toString());
query.setParameter("orderId",orderId);
    return query.executeUpdate();
}

6.hibernate 使用 in 查询 采用的方法是 query.setParameterList("ids", ids)

 

public int updateMult(List<Integer> ids) {
   String hql = "update ServiceOrder mso set mso.isDel = 1 where mso.id in(:ids)";
Query query= this.currentSession().createQuery(hql);  
query.setParameterList("ids", ids); 
   return query.executeUpdate();
}

 

 

分享到:
评论

相关推荐

    Hibernate知识点总结

    ### Hibernate知识点总结 #### 一、Hibernate概述 Hibernate是一个开源的ORM(Object Relational Mapping,对象关系映射)框架,用于Java应用与关系型数据库之间的交互。它通过使用描述对象和数据库之间映射的元...

    hibernate查询方法

    **Hibernate查询方法大全** Hibernate,作为Java领域中最流行的持久化框架之一,提供了多种查询数据的方法。这些方法使得开发者能够高效地从数据库中检索、更新和删除数据,无需编写大量SQL语句。本篇文章将深入...

    通用的hibernate查询

    本篇文章将深入探讨通用的Hibernate查询方法,特别是关于分页查询的应用。 在Hibernate中,查询数据主要通过Criteria、HQL(Hibernate Query Language)和Query API三种方式。首先,让我们来看看Criteria查询。...

    Hibernate方法总结

    这两个方法都用于执行HQL(Hibernate Query Language)查询。`find`返回一个List集合,一次性将所有结果加载到内存,适合于小规模数据的查询。而`iterate`返回一个迭代器,每次调用`next()`方法时才从数据库中获取一...

    Hibernate连表查询 Hibernate连表查询

    根据提供的文件信息,我们可以深入探讨Hibernate中的连表查询方法及其应用。下面将详细介绍与标题、描述及部分代码相关的几个核心知识点: ### Hibernate 连表查询基础 Hibernate 是一个开源的对象关系映射(ORM)...

    struts+hibernate查询所有记录

    ### Struts+Hibernate查询所有记录 #### 一、概述 在Java Web开发中,Struts与Hibernate是非常流行的框架组合,用于构建复杂的企业级应用。本文将详细介绍如何利用Struts和Hibernate来实现对Oracle数据库中所有...

    Hibernate hql查询语法总结

    本文将对Hibernate HQL查询语法进行总结,涵盖基础查询、属性查询、实例化查询以及查询链接等多个方面。 1. 基础查询: 基础查询是最简单的HQL语句,用于获取所有`Student`对象。例如: ```java from Student ``` ...

    Hibernate查询解决方案

    ### Hibernate查询解决方案详解 #### 一、概述 Hibernate 是一个开放源代码的 ORM(对象关系映射)框架,它提供了从 Java 类到数据库表的映射机制,以及数据的查询和获取方式。Hibernate 的核心功能之一是提供了...

    hibernate学习总结文档

    2. **读取(Read)**:`get()` 或 `load()` 方法用于根据主键获取对象,`query()` 或 HQL(Hibernate 查询语言)用于执行更复杂的查询。 3. **更新(Update)**:修改对象后,调用 `update()` 或 `merge()` 方法同步...

    Hibernate课程的总结

    1. Session:是Hibernate的主要工作单元,负责保存、更新和删除对象,以及执行HQL(Hibernate查询语言)。 2. Transaction:处理数据的原子性,确保一组操作要么全部成功,要么全部失败。 **五、CRUD操作** 1. 插入...

    Hibernate_query查询数据表中的一个字段.

    总结,Hibernate提供多种方式查询数据表中的字段,包括HQL、Criteria API和DetachedCriteria,选择合适的方法取决于具体需求。正确理解和使用Hibernate,能够大大提高Java开发中的数据库操作效率。

    Hibernate 参数查询通用方法

    总结来说,Hibernate的参数查询通用方法主要涉及HQL和Criteria API,通过Dao层的抽象可以实现高效的数据查询。在实际开发中,我们需要根据项目的具体需求选择合适的方法,并充分利用Hibernate提供的功能,以提高开发...

    hibernate多表联合查询

    ### Hibernate多表联合查询详解 #### 一、引言 在实际项目开发中,我们经常需要处理复杂的数据库查询,特别是涉及到多个表之间的关联查询。Hibernate作为一款流行的Java持久层框架,提供了一种非常便捷的方式来处理...

    Hibernate4总结文档

    《Hibernate4总结文档》 Hibernate4作为一款强大的Java对象关系映射框架,简化了数据库操作,使得开发者可以更专注于业务逻辑而不是数据库层面的细节。本文将深入探讨Hibernate4的配置和使用,帮助开发者更好地理解...

    Hibernate的查询方式

    ### Hibernate的查询方式详解 #### 引言 Hibernate作为Java领域中最流行的ORM(Object-Relational Mapping)框架之一,提供了一系列高效、灵活的查询机制,旨在桥接对象模型与关系数据库之间的鸿沟。本文将深入...

    Hibernate学习笔记与总结

    **Hibernate学习笔记与总结** Hibernate 是一款开源的对象关系映射(ORM)框架,它为Java开发者提供了一种在关系数据库上操作对象数据的便捷方式。本文将深入探讨Hibernate的核心概念、配置、实体类、映射文件、...

    Hibernate三大类查询总结

    本文将对Hibernate的三大类查询进行详细总结,包括Cretiria查询、HQL查询以及本地SQL查询。 首先,我们来看Cretiria查询,这是Hibernate提供的一种基于对象的查询方式,具有高度的灵活性和可扩展性。`Criteria`接口...

    hibernate实现动态SQL查询

    本篇文章主要探讨如何利用Hibernate实现动态SQL查询,结合XML配置和FREEMARKER模板引擎来生成执行的SQL语句。 一、Hibernate简介 Hibernate作为一款强大的持久层框架,它简化了Java应用程序与数据库之间的交互。...

Global site tag (gtag.js) - Google Analytics