欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決Mybatis-Plus操作分頁后數(shù)據(jù)失效問題

 更新時間:2020年11月30日 09:46:13   作者:李金泉  
這篇文章主要介紹了解決Mybatis-Plus操作分頁后數(shù)據(jù)失效問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

業(yè)務(wù)場景

我們知道在使用PageHelper分頁插件時,會對執(zhí)行PageHelper.startPage(pageNum, pageSize);方法后的第一條查詢語句進行分頁操作。在開發(fā)中總會遇到這樣的業(yè)務(wù)情景,在進行分頁查詢后,需要對獲得的列表數(shù)據(jù)包裝成另一種類型,此時需要對新類型的列表進行分頁,然而由于PageInfo<T>因為泛型的原因,導(dǎo)致處理后的列表不能加入到該類中。

如,我在數(shù)據(jù)庫分頁后查詢到的類為PageInfo<User>,此時改類中的list屬性為User,在當(dāng)前的業(yè)務(wù)場景下,我需要將User類型替換為UserVo類型。

當(dāng)我們對list屬性進行操作時,會同時導(dǎo)致PageInfo類中的其他屬性發(fā)生改變,如total等。

解決方法

//從數(shù)據(jù)庫獲得的Users分頁列表
//當(dāng)我們打印users時,會發(fā)現(xiàn)打印出來的數(shù)據(jù)除了列表數(shù)據(jù)還有分頁屬性
List<User> users = this.list();
//操作users獲得的需要的列表
List<UserVo> userVos = this.list2(users);
//創(chuàng)建User的info類,此時page中的屬性已生成
PageInfo<User> userPage = new PageInfo<>(users);
//創(chuàng)建UserVo的info類
PageInfo<UserVo> userVoPage= new PageInfo<>(userVos );
//將userPage中除看list外的其他屬性復(fù)制到userVoPage中
PageInfoUtil pageInfoUtil = new PageInfoUtil();
pageInfo = pageInfoUtil.getPageVo(userPage ,userVoPage);
pageInfoUtil
public class PageInfoUtil {
 public PageInfo getPageVo(PageInfo pageInfoPo,PageInfo pageInfoVo){
  pageInfoVo.setTotal(pageInfoPo.getTotal());
  pageInfoVo.setEndRow(pageInfoPo.getEndRow());
  pageInfoVo.setHasNextPage(pageInfoPo.isHasNextPage());
  pageInfoVo.setHasPreviousPage(pageInfoPo.isHasPreviousPage());
  pageInfoVo.setIsFirstPage(pageInfoPo.isIsFirstPage());
  pageInfoVo.setIsLastPage(pageInfoPo.isIsLastPage());
  pageInfoVo.setNavigateFirstPage(pageInfoPo.getNavigateFirstPage());
  pageInfoVo.setNavigateLastPage(pageInfoPo.getNavigateLastPage());
  pageInfoVo.setNavigatePages(pageInfoPo.getNavigatePages());
  pageInfoVo.setNavigatepageNums(pageInfoPo.getNavigatepageNums());
  pageInfoVo.setNextPage(pageInfoPo.getNextPage());
  pageInfoVo.setPageNum(pageInfoPo.getPageNum());
  pageInfoVo.setPages(pageInfoPo.getPages());
  pageInfoVo.setPageSize(pageInfoPo.getPageSize());
  pageInfoVo.setPrePage(pageInfoPo.getPrePage());
  pageInfoVo.setSize(pageInfoPo.getSize());
  pageInfoVo.setStartRow(pageInfoPo.getStartRow());
  pageInfoVo.setFirstPage(pageInfoPo.getFirstPage());
  pageInfoVo.setLastPage(pageInfoPo.getLastPage());
  return pageInfoVo;
 }
}

End

想使用秀一點的方法,結(jié)果能力有限,沒有成功,只能使用這種笨方法,如果有更好的方法,歡迎各位指導(dǎo)。

補充知識:mybatis-plus分頁無效, total=0問題(springmvc)

前言

項目中(springmvc)分頁采用mybatis-plus, 頭一回用, 就遇到了如題問題

pom.xml

<dependency>
 <groupId>com.baomidou</groupId>
 <artifactId>mybatis-plus</artifactId>
 <version>3.2.0</version>
</dependency>

mapper繼承了BaseMapper

@Repository
public interface UserMapper extends BaseMapper<UserPo>{
  // 這里代碼沒用, 查詢采用的BaseMapper中的 IPage<T> selectPage(IPage<T> page, @Param("ew") Wrapper<T> queryWrapper);
}

service層

 @Override
 public SysUserVo list(UserQo qo) {
  QueryWrapper<UserPo> queryWrapper = new QueryWrapper<>();
  queryWrapper.like("name", qo.getKeyword())
    .or().
    like("code", qo.getKeyword());
  Page<UserPo> page = new Page<>(qo.getPageNo(), qo.getPageSize());
  IPage<UserPo> userPoIPage = userMapper.selectPage(page, queryWrapper);
  List<UserPo> records = userPoIPage.getRecords();
  long total = userPoIPage.getTotal();// 總記錄數(shù)
  long pages = userPoIPage.getPages();// 查詢結(jié)果數(shù)
  long pageNo = userPoIPage.getCurrent();// 當(dāng)前頁
  long pageSize = userPoIPage.getSize();// 每頁條數(shù)
  List<UserVo> userVos = Lists.newArrayList();
  for (UserPo userPo : records) {
   Integer userId = userPo.getId();
   List<RolePo> roles = userMapper.selectRoles(userId);
   UserVo userVo = UserVo.builder().code(userPo.getCode())
     .name(userPo.getName())
     .rolePo(roles)
     .status(userPo.getStatus())
     .build();
   userVos.add(userVo);
  }
  SysUserVo sysUserVo = SysUserVo.builder()
    .list(userVos)
    .total(total)
    .build();
  return sysUserVo;
 }

結(jié)果分頁并沒有生效, 于是添加攔截器

package com.cebbank.api.config;

import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
import com.baomidou.mybatisplus.extension.plugins.pagination.optimize.JsqlParserCountOptimize;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.transaction.annotation.EnableTransactionManagement;

@Configuration
@EnableTransactionManagement
@MapperScan("com.cebbank.api.mapper")
public class MybatisPlusConfig {
 @Bean
 public PaginationInterceptor paginationInterceptor() {
  PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
  // 設(shè)置請求的頁面大于最大頁后操作, true調(diào)回到首頁,false 繼續(xù)請求 默認(rèn)false
  paginationInterceptor.setOverflow(true);
  // 設(shè)置最大單頁限制數(shù)量,默認(rèn) 500 條,-1 不受限制
  paginationInterceptor.setLimit(100);
  // 開啟 count 的 join 優(yōu)化,只針對部分 left join
  paginationInterceptor.setCountSqlParser(new JsqlParserCountOptimize(true));
  paginationInterceptor.setDialectType("mysql");
  return paginationInterceptor;
 }
}

還是沒生效

最后找到解決方案, 在數(shù)據(jù)源配置中顯式添加分頁插件

 @Bean
 public SqlSessionFactory sqlSessionFactory() throws Exception {
  MybatisSqlSessionFactoryBean sqlSessionFactoryBean = new MybatisSqlSessionFactoryBean();
  sqlSessionFactoryBean.setDataSource(dataSource());
  MybatisConfiguration configuration = new MybatisConfiguration();
  configuration.setMapUnderscoreToCamelCase(true);
  configuration.setDefaultEnumTypeHandler(EnumOrdinalTypeHandler.class);
  sqlSessionFactoryBean.setConfiguration(configuration);
//  sqlSessionFactoryBean.setMapperLocations(resolveMapperLocations());
  sqlSessionFactoryBean.setPlugins(new Interceptor[]{new PaginationInterceptor()});

  return sqlSessionFactoryBean.getObject();
 }

完整配置

package com.cebbank.api.config;

import com.alibaba.druid.pool.DruidDataSource;
import com.baomidou.mybatisplus.core.MybatisConfiguration;
import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
import com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean;
import org.apache.ibatis.plugin.Interceptor;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.type.EnumOrdinalTypeHandler;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.EnableAspectJAutoProxy;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;

import javax.sql.DataSource;


/**
 * @author linyong
 * @date 2020/7/30 16:38
 * @description 數(shù)據(jù)源配置
 **/
@Configuration
@EnableAspectJAutoProxy
@MapperScan("com.cebbank.api.mapper")
public class DBConfig {

 @Value("${spring.datasource.url}")
 private String url;

 @Value("${spring.datasource.driver-class-name}")
 private String driverClassName;

 @Value("${spring.datasource.username}")
 private String username;

 @Value("${spring.datasource.password}")
 private String password;

 @Value("${spring.datasource.initialSize:5}")
 private Integer initialSize;

 @Value("${spring.datasource.maxActive:50}")
 private Integer maxActive;

 @Value("${spring.datasource.maxWait:60000}")
 private Integer maxWait;

 @Value("${spring.datasource.minIdle:5}")
 private Integer minIdle;

 @Value("${spring.datasource.testWhileIdle:true}")
 private Boolean testWhileIdle;

 @Value("${spring.datasource.testOnBorrow:true}")
 private Boolean testOnBorrow;

 @Value("${spring.datasource.testOnReturn:true}")
 private Boolean testOnReturn;

 @Value("${spring.datasource.validationQuery:select 1}")
 private String validationQuery;

// @Value("${mybatis.mapper-locations}")
// private String mapperLocations;


 @Bean
 public DataSource dataSource(){
  DruidDataSource druidDataSource = new DruidDataSource();
  druidDataSource.setUrl(url);
  druidDataSource.setDriverClassName(driverClassName);
  druidDataSource.setUsername(username);
  druidDataSource.setPassword(password);
  druidDataSource.setInitialSize(initialSize);
  druidDataSource.setMaxActive(maxActive);
  druidDataSource.setMaxWait(maxWait);
  druidDataSource.setMinIdle(minIdle);
  druidDataSource.setTestWhileIdle(testWhileIdle);
  druidDataSource.setTestOnBorrow(testOnBorrow);
  druidDataSource.setTestOnReturn(testOnReturn);
  druidDataSource.setValidationQuery(validationQuery);
  return druidDataSource;
 }

// private Resource[] resolveMapperLocations() {
//  ResourcePatternResolver resourceResolver = new PathMatchingResourcePatternResolver();
//  String[] arr = mapperLocations.split(",");
//  List<String> locations = Arrays.asList(arr);
//  List<Resource> resources = new ArrayList();
//  if (locations != null) {
//   for (String mapperLocation : locations) {
//    try {
//     Resource[] mappers = resourceResolver.getResources(mapperLocation);
//     resources.addAll(Arrays.asList(mappers));
//    } catch (IOException e) {
//     // ignore
//    }
//   }
//  }
//  return resources.toArray(new Resource[resources.size()]);
// }

 @Bean
 public SqlSessionFactory sqlSessionFactory() throws Exception {
  MybatisSqlSessionFactoryBean sqlSessionFactoryBean = new MybatisSqlSessionFactoryBean();
  sqlSessionFactoryBean.setDataSource(dataSource());
  MybatisConfiguration configuration = new MybatisConfiguration();
  configuration.setMapUnderscoreToCamelCase(true);
  configuration.setDefaultEnumTypeHandler(EnumOrdinalTypeHandler.class);
  sqlSessionFactoryBean.setConfiguration(configuration);
//  sqlSessionFactoryBean.setMapperLocations(resolveMapperLocations());
  sqlSessionFactoryBean.setPlugins(new Interceptor[]{new PaginationInterceptor()});

  return sqlSessionFactoryBean.getObject();
 }


 @Bean
 public DataSourceTransactionManager transactionManager(){
  DataSourceTransactionManager transactionManager = new DataSourceTransactionManager();
  transactionManager.setDataSource(dataSource());
  return transactionManager;
 }

}

問題解決!

以上這篇解決Mybatis-Plus操作分頁后數(shù)據(jù)失效問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Mybatis批量修改時出現(xiàn)報錯問題解決方案

    Mybatis批量修改時出現(xiàn)報錯問題解決方案

    這篇文章主要介紹了Mybatis批量修改時出現(xiàn)報錯問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-11-11
  • Java進階之SPI機制詳解

    Java進階之SPI機制詳解

    Java SPI機制在很多大型中間建碼,例如Dubbo中均有采用,屬于高級Java開發(fā)的進階必備知識點,務(wù)必要求掌握.文中有非常詳細(xì)的代碼示例及解釋,需要的朋友可以參考下
    2021-05-05
  • Java調(diào)用明華RF讀寫器DLL文件過程解析

    Java調(diào)用明華RF讀寫器DLL文件過程解析

    這篇文章主要介紹了Java調(diào)用明華RF讀寫器DLL文件過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-12-12
  • logback StatusListener的定義方法源碼解讀

    logback StatusListener的定義方法源碼解讀

    這篇文章主要為大家介紹了logback StatusListener的定義方法源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • java數(shù)據(jù)結(jié)構(gòu)基礎(chǔ):循環(huán)鏈表和棧

    java數(shù)據(jù)結(jié)構(gòu)基礎(chǔ):循環(huán)鏈表和棧

    這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)之循環(huán)鏈表、棧的實現(xiàn)方法,結(jié)合實例形式分析了Java數(shù)據(jù)結(jié)構(gòu)中循環(huán)鏈表、棧、的功能、定義及使用方法,需要的朋友可以參考下
    2021-08-08
  • 輕松掌握J(rèn)ava命令模式

    輕松掌握J(rèn)ava命令模式

    這篇文章主要幫助大家輕松掌握J(rèn)ava命令模式,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • 解決spring-cloud-config 多服務(wù)共享公共配置的問題

    解決spring-cloud-config 多服務(wù)共享公共配置的問題

    這篇文章主要介紹了解決spring-cloud-config 多服務(wù)共享公共配置的問題,本文通過多種方法給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • springboot多文件上傳實現(xiàn)使用postman測試多文件上傳接口

    springboot多文件上傳實現(xiàn)使用postman測試多文件上傳接口

    這篇文章主要介紹了springboot多文件上傳實現(xiàn)使用postman測試多文件上傳接口,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Mybatis之通用Mapper動態(tài)表名及其原理分析

    Mybatis之通用Mapper動態(tài)表名及其原理分析

    這篇文章主要介紹了Mybatis之通用Mapper動態(tài)表名及其原理分析,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • Java 使用 HttpClient 發(fā)送 GET請求和 POST請求

    Java 使用 HttpClient 發(fā)送 GET請求和 POST請求

    本文主要介紹了Java 使用 HttpClient 發(fā)送 GET請求和 POST請求,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08

最新評論