公众号:架构师与哈苏
关注公众号进入it交流群! 公众号:架构师与哈苏 不定时都会推送一些实用的干货。。。
posts - 305,comments - 4,views - 10万

SpringDataJpa

Spring Data JPA是较大的Spring Data系列的一部分,可轻松实现基于JPA的存储库。该模块处理对基于JPA的数据访问层的增强支持。它使构建使用数据访问技术的Spring支持的应用程序变得更加容易。

实现应用程序的数据访问层已经很长一段时间了。为了执行简单查询以及执行分页和审核,必须编写太多样板代码。Spring Data JPA旨在通过将工作量减少到实际需要的数量来显着改善数据访问层的实现。作为开发人员,您将编写包括自定义finder方法在内的存储库接口,Spring会自动提供实现。

使用EntityManager 来创建原生查询语句

在service层的代码:

    @PersistenceContext
    EntityManager entityManager;

 @Override
 public Object findMeetingSignRecoredPage(Long meetingId, Integer pageIndex, Integer pageSize) {

        MeenoAssert.notNull(meetingId, ErrEnum.MEETING_ID_IS_EMPTY);
        Meeting meeting = this.meetingRepository.getOne(meetingId);
        MeenoAssert.notNull(meeting,ErrEnum.MEETING_IS_NOT_EXIST);

        Pageable pageable = PageUtils.getPageable(pageIndex,pageSize);

        StringBuilder sql = new StringBuilder();
        sql.append(" select ep.name,MAX(r.sign) from mnt_emp_rel_meeting as e  ");
        sql.append(" left join mnt_sign_record as r on(r.employee_id=e.employee_id)  ");
        sql.append(" left join mnt_employee as ep on(ep.id = e.employee_id) ");
        sql.append(" where e.meeting_id = ? ");
        sql.append(" order by  r.sign desc,r.create_date asc ");


        Query query = entityManager.createNativeQuery(sql.toString());

        query.setFirstResult(pageable.getOffset());
        query.setMaxResults(pageable.getPageSize());
        query.setParameter(1,meetingId);

        List<Object[]> list = query.getResultList();
        List<SignRecordView> listView = Lists.newArrayList();

        if(list != null && !list.isEmpty()){
            for (Object[] objects : list) {
                String empName = objects[0]==null?null:objects[0].toString();
                Integer sign = objects[1]==null?Constants.SIGN_RECORD_NO:Integer.parseInt(objects[1].toString());
                SignRecordView view = new SignRecordView();
                view.setEmployeeName(empName);
                view.setSign(sign);
                listView.add(view);
            }
        }

        //count
        StringBuilder countSql = new StringBuilder();
        countSql.append(" select count(distinct e.id) from mnt_emp_rel_meeting as e  ");
        countSql.append(" left join mnt_sign_record as r on(r.employee_id=e.employee_id)  ");
        countSql.append(" left join mnt_employee as ep on(ep.id = e.employee_id) ");
        countSql.append(" where e.meeting_id = ? ");
        countSql.append(" order by  r.sign desc,r.create_date asc ");

        Query countQuery = entityManager.createNativeQuery(countSql.toString());
        countQuery.setParameter(1,meetingId);
        Object singleResult = countQuery.getResultList().get(0);
        Integer count = singleResult==null?0:Integer.valueOf(singleResult.toString());


        Map<String, Object> resultPage = PageUtils.getResultPage(count, listView);

        return resultPage;
    }

PageUtils工具类代码如下:

package com.meeno.framework.page.utils;

import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import lombok.Data;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Map;

/**
 * @description: 分页工具类
 * @author: Wzq
 * @create: 2019-12-26 20:19
 */
@Data
public class PageUtils {



    /**
    *@Description 获取集合分页对象
    *@Param [list, pageIndex, pageSize]
    *@Return void
    *@Author Wzq
    *@Date 2020/1/6
    *@Time 14:07
    */
    public static  <T> Map<String,Object> getCollectionPage(List<T> list, Pageable pageable){
        if(list==null||list.isEmpty()){
            return PageUtils.getResultPage(0,null );
        }

        int offset = pageable.getOffset();
        int pageSize = pageable.getPageSize();

        List<T> listView = Lists.newArrayList();

        if(list!=null && !list.isEmpty()){
            if(list.size() < offset){
                return PageUtils.getResultPage(0,null );
            }
            for(;list.size() > offset && pageSize != 0 ; offset++,pageSize--){
                listView.add(list.get(offset));
            }
            return PageUtils.getResultPage(list.size(),listView);
        }
        return PageUtils.getResultPage(0,null );
    }




    /**
    *@Description 根据pageIndex和pageSize获取Pageable
    *@Param [pageIndex, pageSize]
    *@Return org.springframework.data.domain.Pageable
    *@Author Wzq
    *@Date 2019/12/27
    *@Time 11:12
    */
    public static Pageable getPageable(Integer pageIndex, Integer pageSize){
        if(pageIndex==null){
            pageIndex = 0;
        }else{
            pageIndex--;
        }
        if(pageSize==null){
            pageSize = 10;
        }
        PageRequest pageRequest = new PageRequest(pageIndex, pageSize);
        return pageRequest;
    }

    /**
    *@Description 获取分页返回对象
    *@Param [totalCount, list]
    *@Return java.util.Map<java.lang.String,java.lang.Object>
    *@Author Wzq
    *@Date 2019/12/26
    *@Time 20:22
    */
    public  static  Map<String,Object> getResultPage(Page<?> page, List<?> list){
        Map<String,Object> resultPageMap = Maps.newHashMap();
        resultPageMap.put("totalCount",page.getTotalElements());
        resultPageMap.put("list",list);
        return resultPageMap;
    }

    public  static  Map<String,Object> getResultPage(Integer count, List<?> list){
        Map<String,Object> resultPageMap = Maps.newHashMap();
        resultPageMap.put("totalCount",count);
        resultPageMap.put("list",list);
        return resultPageMap;
    }


}

posted on   公众号/架构师与哈苏  阅读(2709)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示