springboot 给封装好的Page重新赋值(将id改成name)

在关联查询中,有时我们需要吧a表中的id存到b表中的某个字段(aId)中,这是在分页的时候发现我们不能在页面中显示aId,我们只需要a表的name属性怎么办呢?我们需要给返回的Page对象重新赋值

在b的实体类中需要映射a.name字段,@Transient注解:表示该属性并非一个到数据库表的字段的映射

如:

public class Follow extends IdEntity {

    private Long memberId;//会员id

    private Long followMemberId;//被关注人id

    @Transient
    private String memberNickName;//另一个表需要映射的name
}

分页查询在service中

 public Page<Follow> findByPage(Pageable pageable, String memberNickName) {
        Specification<Follow> specification = new Specification<Follow>() {
                    @Override
                    public Predicate toPredicate(Root<Follow> root, CriteriaQuery<?> criteriaQuery, CriteriaBuilder criteriaBuilder) {
                        List<Predicate> predicates = new ArrayList<>();
                        if(!memberNickName.isEmpty()||memberNickName!=null){
                           Member member = memberService.findByMemberNickName(memberNickName, MemberStatus.正常.getValue()) ;
                            if(member!=null){
                                CriteriaBuilder.In<Long> in = criteriaBuilder.in(root.get("memberId"));
                                in.value(member.getId());//模糊查询
                                predicates.add(in);
                            }
                        }
                        return criteriaBuilder.and(predicates.toArray(new Predicate[0]));
                    }
                };
                Page<Follow> followList = followRepository.findAll(specification, pageable);
                for(int i=0;i<followList.getContent().size();i++){
                    transformMember(followList,i);//转化
                }
                return followList;
    }

 

将获取到的Content进行转化、重新赋值

 private void transformMember(Page<Follow> followList,int i){
        Long memberId = followList.getContent().get(i).getMemberId();//获取到b表中id
        Optional<Member> member = memberService.findById(memberId);//通过b表的id去a表中查询
        followList.getContent().get(i).setMemberNickName(member.get().getNickname());
    }

在controller中调用并返回

SpringBoot封装Starter是一种方便的方式,可以将一些通用的配置和功能封装成一个可复用的模块,以供其他项目使用。通过引用和的内容,我们可以了解到封装自己的Starter主要需要进行以下几个步骤: 1. 创建一个普通的Java项目,作为Starter的源代码根目录。 2. 在项目的pom.xml文件中添加必要的依赖,例如Spring Boot相关的依赖。 3. 在项目的src/main/resources目录下创建META-INF目录,并在其中创建一个名为spring.factories的文件。在该文件中,配置Starter的自动配置类,如com.example.myspringbootstarter.MyServiceAutoConfiguration。这样Spring Boot在启动时会自动加载该自动配置类。 4. 在Starter项目中实现需要封装的功能和配置,可以包括自定义的Bean、配置类、自动配置类等。 5. 将封装好的Starter项目打包,并发布到Maven仓库供其他项目使用。 通过引用的内容,我们还可以了解到在使用封装好的Starter时,需要在项目的pom.xml文件中添加对Starter的依赖。例如,使用groupId为com.example,artifactId为my-spring-boot-starter的Starter,并指定版本号为0.0.1-SNAPSHOT。 综上所述,SpringBoot封装Starter是一种将通用功能和配置封装成可复用模块的方式,方便项目开发和维护。通过合理配置和使用Starter,可以提高开发效率并降低项目的复杂性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SpringBoot封装自己的Starter的实现方法](https://download.csdn.net/download/weixin_38705252/12749617)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [SpringBoot封装自己的starter](https://blog.csdn.net/ldllovegyh/article/details/124861446)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值