public List findStockByStockPO(List Parameter1, int from, int size,
StockPO po) {
logger.info("##StartfindStockByStockPO");
List list = new ArrayList();
List result = new ArrayList();
super.getSession().clear();
Criteria criteria = super.getSession().createCriteria(StockPO.class);
criteria.add(Restrictions.eq("stockPK.country", po.getStockPK()
.getCountry()));
criteria.add(Restrictions.eq("marketType", po.getMarketType()));
criteria.add(Restrictions.eq("currencyType", po.getCurrencyType()));
if (null != po.getStockPK().getStockNO())
criteria.add(Restrictions.eq("stockPK.stockNO", po.getStockPK()
.getStockNO()));
if (null != po.getStockInternationalId())
criteria.add(Restrictions.eq("stockInternationalId", po
.getStockInternationalId()));
if (null != po.getStockReservationType4Entity())
criteria.add(Restrictions.eq("stockReservationType4Entity", po
.getStockReservationType4Entity()));
if (null != po.getStockReservationType4TDCC())
criteria.add(Restrictions.eq("stockReservationType4TDCC", po
.getStockReservationType4TDCC()));
if (null != po.getStockReservationType4Strip())
criteria.add(Restrictions.eq("stockReservationType4Strip", po
.getStockReservationType4Strip()));
criteria.setFirstResult(from);
criteria.setMaxResults(size);
//from为起始页数size为一页10条数据
//获得10条记录的集合
result = criteria.list();
list.add(0, result);
criteria.setFirstResult(0);
criteria.setProjection(Projections.projectionList().add(
Projections.rowCount()));
//获得满足条件的总记录数
int count = ((Integer) criteria.uniqueResult()).intValue();
list.add(1, new Integer(count));
logger.info("##LIST" + list.size() + "--" + count);
return list;
}
分享到:
相关推荐
在这个场景中,我们将探讨如何使用JPA进行分页查询以及带有条件的分页查询。 首先,为了使用Spring Data JPA,我们需要在项目中引入相应的依赖。在Maven的pom.xml文件中,你需要添加`spring-boot-starter-data-jpa`...
下面是一个简单的示例代码片段,演示了如何使用Hibernate Criteria进行分页查询: ```java Session session = sessionFactory.openSession(); Transaction tx = null; try { tx = session.beginTransaction(); /...
JPA 提供了分页查询功能,可以根据需要对查询结果进行分页处理。分页查询可以使用 Pageable 对象来实现。Pageable 对象提供了分页查询的相关信息,包括当前页码、每页记录数等。 JPA 复杂查询 JPA 复杂查询可以...
在Hibernate中,我们通常使用`Criteria`或`Query` API进行分页查询。`Criteria`提供了一种更面向对象的方式来执行SQL查询,而`Query` API则对应于原生的SQL语句。在这些API中,我们可以设置`setFirstResult()`和`...
以下是一个简单的使用Criteria进行分页查询的例子: 1. 创建Criteria实例,设置查询条件。 ```java Session session = sessionFactory.openSession(); Criteria criteria = session.createCriteria(User.class); ``...
分页查询是数据库操作中一个常见且重要的技术,特别是在处理大量数据时,为了提高用户体验和系统性能,我们通常不会一次性加载所有数据,而是采用分页的方式逐步加载。在这个主题下,我们将探讨分页查询的基本概念、...
总结,"Hibernate 多表连接分页查询示范项目"是一个实用的示例,它展示了如何在实际应用中利用 Hibernate Criteria API 实现复杂查询和分页,对于学习和掌握 Hibernate 的高级特性和数据库操作技巧非常有帮助。...
4. **设置查询参数**:如果需要分页查询,可以通过Criteria的setFirstResult()和setMaxResults()方法设置起始位置和结果数量。 5. **执行查询并处理结果**:调用Criteria的list()方法执行查询,返回List集合,遍历...
Hibernate提供了Criteria API,可以更面向对象地进行分页查询。我们可以创建`Criteria`对象,然后使用`setFirstResult`设置起始位置(相当于OFFSET),`setMaxResults`设置每页显示的记录数(相当于LIMIT)。此外,...
通过这个实现,用户可以在前端输入查询条件,后端会根据这些条件进行数据库查询,并返回分页结果,Thymeleaf模板将结果渲染成用户友好的界面。这在实际应用中非常常见,能够提高用户体验并减轻服务器负载。
在实际开发中,分页查询通常结合Hibernate的Criteria API或者HQL(Hibernate Query Language)进行,这样可以方便地指定查询条件并进行分页。例如,我们可以使用`setFirstResult()`和`setMaxResults()`方法来设置...
这里可以使用Hibernate的Criteria API或者HQL(Hibernate Query Language)来实现分页查询。 4. **DAO层**: - 在DAO层,使用Criteria API或HQL编写分页查询语句。例如,使用`setFirstResult()`设置开始位置(即...
在IT行业中,数据分页和高级查询是数据库管理和Web应用开发中的重要技术。尤其是在处理大量数据时,这两种技术显得尤为重要,因为它们可以帮助提高系统性能,优化用户体验,并且提供灵活的数据检索方式。 首先,...
在Hibernate中,我们可以使用Criteria API或HQL(Hibernate Query Language)来实现分页查询。这两种方式都能有效地完成任务,但各有特点。Criteria API更具有面向对象的特性,而HQL则接近于SQL,对于熟悉SQL的...
除了Criteria查询,还可以使用HQL(Hibernate Query Language)进行分页查询,HQL是Hibernate提供的面向对象的查询语言,语法类似SQL。以下是一个使用HQL分页查询的例子: ```java String hql = "from User"; Query...
在Hibernate中使用HQL进行分页查询主要依赖于`setFirstResult()`和`setMaxResults()`两个方法。其中: - `setFirstResult(int offset)`: 设置查询的起始位置。 - `setMaxResults(int maxResults)`: 设置查询的最大...
总结一下,利用Struts2、Hibernate和Maven进行分页查询,需要配置好Maven的依赖,编写Struts2的Action和Interceptor,利用Hibernate的Criteria API处理数据库查询,最后在JSP页面上实现分页展示。这个过程涉及到项目...
总结,Hibernate的分页查询是其强大功能的一部分,通过Criteria API、HQL或自定义SQL,我们可以轻松地在Java应用中实现数据库的分页操作。在实际开发中,应结合数据库特性和性能需求,选择最合适的分页策略。
5. **性能优化**:为了提高分页查询的效率,可以在数据库层面进行优化,例如创建索引,或者使用`LIMIT`和`OFFSET`关键字(MySQL特有的分页方式)。此外,还可以考虑缓存策略,如使用Hibernate的二级缓存,减少对...
在Hibernate中,可以使用`Criteria`或`Query`接口来进行分页查询。以下是一个使用`Criteria`接口进行分页查询的示例代码: 1. **创建Session对象**: - 首先需要创建一个`Session`对象,这是Hibernate的核心对象之...