多个list合并进行分页

需求背景:多个表的数据查询结果集list,最后需要合并给前台页面进行分页展示

技术栈:google的guava的partition方法

pom依赖:

<dependency>
   <groupId>com.google.guava</groupId>
   <artifactId>guava</artifactId>
   <version.guava>21.0</version.guava>
</dependency>

封装业务方法:

public static List<List> partitionList(List list,Integer pageSize){
    List<List> pageList = Lists.partition(list, pageSize);
    return pageList;
}

业务调用(伪代码):

private List<List> getPageList(requestDto){
//list1
List<ItemInfoDto> distinctSyncPaisItems = allSyncItems.stream().distinct().collect(Collectors.toList());
//list2
List<ItemInfoDto> distinctLimitResult = allLimitItems.stream().distinct().collect(Collectors.toList());
List<ItemInfoDto> allItemInfoList=new ArrayList<>();
//收集所有list然后调用上面封装好的分页方法
allItemInfoList.addAll(distinctSyncPaisItems);
allItemInfoList.addAll(distinctLimitResult);
List<List> lists = PageUtil.partitionList(allItemInfoList,requestDto.getPageSize());
return lists;
}

前端展示(伪代码):

private responseDto getItemListModuleInfo(){
   List<List> list=getPageList(requestDto);
   responseDto.setPages(list.size()); 
   responseDto.setItems(list.get(requestDto.getPageNum()-1));
}

Spring Boot 支持多数据源,可以通过配置不同的数据源来实现多个数据库的访问。下面是一个简单的实现: 1. 配置多个数据源 在 `application.properties` 文件中配置多个数据源,例如: ``` # 第一个数据源 spring.datasource.url=jdbc:mysql://localhost:3306/db1 spring.datasource.username=user1 spring.datasource.password=pass1 # 第二个数据源 datasource2.url=jdbc:mysql://localhost:3306/db2 datasource2.username=user2 datasource2.password=pass2 ``` 2. 配置多个 JdbcTemplate 在 Spring Boot 中,可以使用 `JdbcTemplate` 来操作数据库。因此,我们需要配置多个 `JdbcTemplate` 实例,分别对应不同的数据源。例如: ```java @Configuration public class DataSourceConfig { @Bean(name = "dataSource1") @ConfigurationProperties(prefix = "spring.datasource") public DataSource dataSource1() { return DataSourceBuilder.create().build(); } @Bean(name = "dataSource2") @ConfigurationProperties(prefix = "datasource2") public DataSource dataSource2() { return DataSourceBuilder.create().build(); } @Bean(name = "jdbcTemplate1") public JdbcTemplate jdbcTemplate1(@Qualifier("dataSource1") DataSource dataSource) { return new JdbcTemplate(dataSource); } @Bean(name = "jdbcTemplate2") public JdbcTemplate jdbcTemplate2(@Qualifier("dataSource2") DataSource dataSource) { return new JdbcTemplate(dataSource); } } ``` 3. 实现分页查询 假设我们要对两个数据源中的同一个表进行分页查询,可以按照以下步骤实现: - 在实体类中定义查询条件和分页参数 ```java public class UserQuery { private String name; private int pageNo; private int pageSize; // 省略 getter 和 setter 方法 } ``` - 在 DAO 层中使用 JdbcTemplate 进行查询 ```java @Repository public class UserDao { @Autowired @Qualifier("jdbcTemplate1") private JdbcTemplate jdbcTemplate1; @Autowired @Qualifier("jdbcTemplate2") private JdbcTemplate jdbcTemplate2; public List<User> queryUsers(UserQuery query) { int offset = (query.getPageNo() - 1) * query.getPageSize(); int limit = query.getPageSize(); String sql = "SELECT * FROM user WHERE name LIKE ? LIMIT ?, ?"; List<User> users1 = jdbcTemplate1.query(sql, new Object[]{"%" + query.getName() + "%", offset, limit}, new BeanPropertyRowMapper<>(User.class)); List<User> users2 = jdbcTemplate2.query(sql, new Object[]{"%" + query.getName() + "%", offset, limit}, new BeanPropertyRowMapper<>(User.class)); List<User> result = new ArrayList<>(); result.addAll(users1); result.addAll(users2); return result; } } ``` 在上述代码中,我们使用了 `@Autowired` 和 `@Qualifier` 注解来注入不同的 `JdbcTemplate` 实例。然后,我们可以使用 `query` 方法对两个数据源中的表进行分页查询,最后将结果合并返回。 注意事项: - 在 SQL 语句中需要使用 LIMIT 语句进行分页。 - 不同的数据源需要使用不同的 `JdbcTemplate` 实例,否则会出现错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

努力终会有回报

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值