@PersistenceContext
private EntityManager entityManager;

十分操蛋。

需要两步。

第一步,查询一共需要多少条。

第二步   分页得到数据

Query query = this.entityManager.createNativeQuery(sb2.toString());

query.unwrap(SQLQuery.class).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
// 获取总结果集
List<ExceptionAnalysis> maps2 = query.getResultList(); // 设置分页
query.setFirstResult((page - 1) * size);
query.setMaxResults(size); // 获取分页查询结果集
List<ExceptionAnalysis> list = query.getResultList();
//封装的分页
PageResult pageResult = new PageResult(Long.valueOf(maps2.size()), list);

上面的是返回map ,如果要返回对象

Query query = getEntityManager().createNativeQuery(sb.toString());
query.unwrap(SQLQuery.class).setResultTransformer(new Testtrans(DealFlow.class));
List<ExceptionAnalysisDetail> maps = query.getResultList();
// 设置分页
query.setFirstResult((page - 1) * size);
query.setMaxResults(size);
// 获取查询结果集
List<DealFlow> list = query.getResultList();
PageResult pageResult = new PageResult(Long.valueOf(maps.size()), list);
return pageResult;
Testtrans类
package com.mairuide._frame.utils;

import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
import java.math.BigDecimal;
import java.sql.Timestamp; import org.hibernate.transform.AliasToBeanResultTransformer; public class Testtrans extends AliasToBeanResultTransformer {
private Class resultClass; public Testtrans(Class resultClass) {
super(resultClass);
this.resultClass = resultClass;
} private static final long serialVersionUID = 1L; public Object transformTuple(Object[] tuple, String[] aliases) {
Object obj = null;
try {
obj = resultClass.newInstance();
} catch (InstantiationException e1) {
e1.printStackTrace();
} catch (IllegalAccessException e1) {
e1.printStackTrace();
}
Method[] methods = resultClass.getMethods();// 返回这个类里面方法的集合
Field[] fields = resultClass.getDeclaredFields();
for (int k = 0; k < aliases.length; k++) {
String aliase = getKey(fields, aliases[k]);
char[] ch = aliase.toCharArray();
ch[0] = Character.toUpperCase(ch[0]);
String s = new String(ch);
String[] names = new String[] { ("set" + s).intern(), ("get" + s).intern(), ("is" + s).intern(),
("read" + s).intern() };
Method setter = null;
Method getter = null;
int length = methods.length;
for (int i = 0; i < length; ++i) {
Method method = methods[i];
/**
* 检查该方法是否为公共方法,如果非公共方法就继续
*/
if (!Modifier.isPublic(method.getModifiers()))
continue;
String methodName = method.getName(); for (String name : names) {
if (name.equals(methodName)) {
if (name.startsWith("set") || name.startsWith("read"))
setter = method;
else if (name.startsWith("get") || name.startsWith("is"))
getter = method; }
}
}
if (getter != null) {
Object[] param = buildParam(getter.getReturnType().getName(), tuple[k]);
try {
setter.invoke(obj, param);
} catch (Exception e) {
e.printStackTrace();
}
}
}
return obj;
} private final static Object[] buildParam(String paramType, Object value) {
Object[] param = new Object[1];
if (paramType.equalsIgnoreCase("java.lang.String")) {
param[0] = (String) (value);
} else if (paramType.equalsIgnoreCase("int") || paramType.equalsIgnoreCase("java.lang.Integer")) {
if (value instanceof BigDecimal) {
param[0] = ((BigDecimal) (value)).intValue();
} else {
param[0] = (Integer) (value);
}
} else if (paramType.equalsIgnoreCase("long") || paramType.equalsIgnoreCase("java.lang.Long")) {
param[0] = (Long) (value);
} else if (paramType.equalsIgnoreCase("double") || paramType.equalsIgnoreCase("java.lang.Double")) {
param[0] = (Double) (value);
} else if (paramType.equalsIgnoreCase("BigDecimal") || paramType.equalsIgnoreCase("java.math.BigDecimal")) {
param[0] = (BigDecimal) (value);
} else if (paramType.equalsIgnoreCase("float") || paramType.equalsIgnoreCase("java.lang.Float")) {
param[0] = (Float) (value);
} else if (paramType.equalsIgnoreCase("char") || paramType.equalsIgnoreCase("Character")) {
param[0] = (char) (value);
} else if (paramType.equalsIgnoreCase("timestamp") || paramType.equalsIgnoreCase("java.sql.Timestamp")) {
param[0] = (Timestamp) (value);
}
return param;
} private String getKey(Field[] fields, String aliase) {
String result = aliase;
try {
for (Field f : fields) {
String fieldName = f.getName();
String temp = fieldName.toUpperCase();
if (fieldName.equals(aliase) || temp.equals(aliase)) {
result = fieldName;
break;
}
}
} catch (Exception e) {
}
return result;
}
}

entityManager分页的更多相关文章

  1. SpringDataJpa使用原生sql(EntityManager)动态拼接,分页查询

    SpringDataJpa Spring Data JPA是较大的Spring Data系列的一部分,可轻松实现基于JPA的存储库.该模块处理对基于JPA的数据访问层的增强支持.它使构建使用数据访问技 ...

  2. Spring Boot-------JPA——EntityManager构建通用DAO

    EntityManager EntityManager 是用来对实体Bean 进行操作的辅助类.他可以用来产生/删除持久化的实体Bean,通过主键查找实体bean,也可以通过EJB3 QL 语言查找满 ...

  3. spring data jpa 分页查询

    https://www.cnblogs.com/hdwang/p/7843405.html spring data jpa 分页查询   法一(本地sql查询,注意表名啥的都用数据库中的名称,适用于特 ...

  4. SpringData分页功能

    在SpringData中实现分页功能我们需要将接口实现PagingAndSortingRepository这个接口提供了分页查询的方法 Page<T> findAll(Pageable p ...

  5. SpringDataJPA - 复杂查询总结 (多表关联 以及 自定义分页 )

    实体类 @Entity @Table(name = "t_hotel") @Data public class THotel { @Id private int id; priva ...

  6. spring data jpa分页5种方法

    7.12.12 分页 本地sql查询 注意表名啥的都用数据库中的名称, 适用于特定数据库的查询 public interface UserRepository extends JpaRepositor ...

  7. mysql实现分页的几种方式

    mysql实现分页的几种方式: 第一种:使用框架自带的pageable来进行分页 package com.cellstrain.icell.repository.repositoryImpl; imp ...

  8. sqlserver实现分页的几种方式

    sqlserver实现分页的几种方式 第一种:使用org.springframework.data.domain.Page来进行分页 package com.cellstrain.icell.repo ...

  9. jQuery分页插件(jquery.page.js)的使用

    效果描述: 不用分页即可显示的jQuery插件 jQuery分页插件——jQuery.page.js用法很简单,效果很棒   1.前端   首先html的head中引入相关css与js <lin ...

随机推荐

  1. ZOJ 1403 解密

    参考自:https://www.cnblogs.com/ECJTUACM-873284962/p/6412212.htmlSafecracker Time Limit: 2 Seconds       ...

  2. 基准对象object中的基础类型----集合 (七)

    object有如下子类: CLASSES object basestring str unicode buffer bytearray classmethod complex dict enumera ...

  3. 洛谷P2722总分题解

    题目 这个题是一个裸的完全背包问题,但是数组需要开大, 代码 #include<iostream> using namespace std; int n,m,v,i; int c[1000 ...

  4. Django+Vue打造购物网站(二)

    配置后台管理 xadmin直接使用之前的在线教育的那个就可以了 users/adminx.py #!/usr/bin/env python # -*- coding: utf-8 -*- # @Tim ...

  5. BZOJ 1497 最大获利

    最大权闭合子图 对于这个题,可以抽象成一个图论模型,如果我们把用户与其要求建立的中转站连边,获得的利益看成正权值,付出的代价看成负权值,我们可以发现,选取一个用户的时候,就相当于选取了一个闭合子图. ...

  6. poj 2226 Muddy Fields(水二分图)

    Rain has pummeled the cows' field, a rectangular grid of R rows and C columns (1 <= R <= 50, 1 ...

  7. css基本语法及页面引用

    css基本语法 css的定义方法是: 选择器 { 属性:值; 属性:值; 属性:值;} 选择器是将样式和页面元素关联起来的名称,属性是希望设置的样式属性每个属性有一个或多个值.代码示例: div{ w ...

  8. 子网站不继承父的WEBCONFIG

    环境 W10 IIS10  / WIN2012 IIS上以前有一个网站,后来写了一个接口项目,需要当成WEB应用程序挂到这网站下. 在右击添加应用程序,指向接口项目后.发现访问不了接口项目.死活配置有 ...

  9. HDU1285确定比赛名次

    确定比赛名次                                Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/ ...

  10. GuGuFishtion HDU - 6390 (杭电多校7E)

    啊啊啊啊...全在纸上 字丑...算了算了 然后除法部分都用逆元就好了 还有逆元打表....学到了...牛逼 #include<map> #include<set> #incl ...