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

mybatis-plus分頁查詢的實現(xiàn)示例

 更新時間:2020年08月26日 14:12:58   作者:一生。  
這篇文章主要介紹了mybatis-plus分頁查詢的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

按照官方文檔進行的配置:快速開始|mybatis-plus

引入依賴:

<!-- 引入mybatisPlus -->
    <dependency>
   <groupId>com.baomidou</groupId>
   <artifactId>mybatis-plus-boot-starter</artifactId>
   <version>3.2.0</version>
  </dependency>
  <!-- 引入mysql驅動包 -->
  <dependency>
   <groupId>mysql</groupId>
   <artifactId>mysql-connector-java</artifactId>
   <version>5.1.27</version>
  </dependency>
  <!-- 引入Druid依賴,阿里巴巴所提供的數(shù)據(jù)源 -->
  <dependency>
   <groupId>com.alibaba</groupId>
   <artifactId>druid</artifactId>
   <version>1.0.29</version>
    </dependency>

在application.yml配置

spring:
 datasource:
 type: com.alibaba.druid.pool.DruidDataSource
 driver-class-name: com.mysql.jdbc.Driver
 url: jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=UTF-8
 username: root
 password: 123456

在啟動類上面添加@MapperScan注解,掃描mapper包

@SpringBootApplication
@MapperScan("com.qiao.demo02.mapper")
public class SpringbootDemo02Application {

 public static void main(String[] args) {
  SpringApplication.run(SpringbootDemo02Application.class, args);
 }

}

新建User和UserMapper

user類

@Data
public class User {
 @TableId
 private Integer userId;
 private String userName;
 private Integer userAge;
 private String userEmail;
}

UserMapper接口

 public interface UserMapper extends BaseMapper<User> {
 
 }

最重要的是繼承BaseMapper<E>接口:里面聲明了很強大的CRUD方法

public interface BaseMapper<T> extends Mapper<T> {
 int insert(T entity);

 int deleteById(Serializable id);

 int deleteByMap(@Param("cm") Map<String, Object> columnMap);

 int delete(@Param("ew") Wrapper<T> wrapper);

 int deleteBatchIds(@Param("coll") Collection<? extends Serializable> idList);

 int updateById(@Param("et") T entity);

 int update(@Param("et") T entity, @Param("ew") Wrapper<T> updateWrapper);

 T selectById(Serializable id);

 List<T> selectBatchIds(@Param("coll") Collection<? extends Serializable> idList);

 List<T> selectByMap(@Param("cm") Map<String, Object> columnMap);

 T selectOne(@Param("ew") Wrapper<T> queryWrapper);

 Integer selectCount(@Param("ew") Wrapper<T> queryWrapper);

 List<T> selectList(@Param("ew") Wrapper<T> queryWrapper);

 List<Map<String, Object>> selectMaps(@Param("ew") Wrapper<T> queryWrapper);

 List<Object> selectObjs(@Param("ew") Wrapper<T> queryWrapper);

 IPage<T> selectPage(IPage<T> page, @Param("ew") Wrapper<T> queryWrapper);

 IPage<Map<String, Object>> selectMapsPage(IPage<T> page, @Param("ew") Wrapper<T> queryWrapper);
}

分頁查詢

這點官方文檔講的也很詳細:https://mp.baomidou.com/guide/page.html

新建一個config包,在里面建一個MybatisPlus配置類 返回一個分頁攔截器

package com.qiao.demo02.config;

@Configuration
@ConditionalOnClass(value = {PaginationInterceptor.class})
public class MybatisPlusConfig {
 @Bean
 public PaginationInterceptor paginationInterceptor() {
  PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
  return paginationInterceptor;
 }
}

這樣就能使用mybatis的分頁功能了

Junit測試

@Resource
 private UserMapper userMapper;
 @Test
 public void queryUserForPage(){
  IPage<User> userPage = new Page<>(2, 2);//參數(shù)一是當前頁,參數(shù)二是每頁個數(shù)
  userPage = userMapper.selectPage(userPage, null);
  List<User> list = userPage.getRecords();
  for(User user : list){
   System.out.println(user);
  }
 }

Controller返回json串

先定義一個包裝類UserVo,用來保存分頁所需要的數(shù)據(jù)

package com.qiao.demo02.vo;

@Data
public class UserVo {
 private Integer current;
 private Integer size;
 private Long total;
 private List<User> userList;
}

然后在控制器編寫代碼,這里省略了service層,實際開發(fā)業(yè)務代碼寫在service層,Controller只負責:接受參數(shù)、調用service層方法處理業(yè)務邏輯,返回結果

Controller類貼上了@RestController注解

 @GetMapping("queryUser")
 public UserVo queryList(Integer current, Integer size) {
  /**
   * 這些代碼應該寫在service層
   */
  UserVo userVo = new UserVo();
  IPage<User> page = new Page<>(current, size);
  userMapper.selectPage(page, null);
  userVo.setCurrent(current);
  userVo.setSize(size);
  userVo.setTotal(page.getTotal());
  userVo.setUserList(page.getRecords());
  return userVo;
 }

附上結果,前端直接處理json數(shù)據(jù)即可

到此這篇關于mybatis-plus分頁查詢的實現(xiàn)示例的文章就介紹到這了,更多相關mybatis-plus 分頁查詢 內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • java明文密碼三重加密方法

    java明文密碼三重加密方法

    這篇文章主要介紹了java明文密碼加密,對一個明文密碼進行了三重加密:第一層柵欄一次,第二層在柵欄一次,第三層在一次摩斯加密,感興趣的小伙伴們可以參考一下
    2016-07-07
  • Java實現(xiàn)Http工具類的封裝操作示例

    Java實現(xiàn)Http工具類的封裝操作示例

    這篇文章主要介紹了Java實現(xiàn)Http工具類的封裝操作,涉及java針對http請求與響應、遠程交互與字符串拼接等操作封裝技巧,需要的朋友可以參考下
    2018-01-01
  • Java如何獲取文件夾下所有壓縮包下指定文件

    Java如何獲取文件夾下所有壓縮包下指定文件

    在Java中,通過遍歷文件夾并對壓縮包進行解析,可以實現(xiàn)提取指定文件的功能,如文檔、PDF等,該過程中可增加過濾條件來適應不同需求,例如文件類型或文件名過濾,該方法適用于處理大量數(shù)據(jù)時的文件管理和數(shù)據(jù)提取
    2024-09-09
  • JavaWeb建立簡單三層項目步驟圖解

    JavaWeb建立簡單三層項目步驟圖解

    這篇文章主要介紹了JavaWeb建立簡單三層項目步驟圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-07-07
  • 淺談Java隨機數(shù)的原理、偽隨機和優(yōu)化

    淺談Java隨機數(shù)的原理、偽隨機和優(yōu)化

    這篇文章主要介紹了淺談Java隨機數(shù)的原理、偽隨機和優(yōu)化,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • Java如何為 PPT 中的圖形添加陰影效果

    Java如何為 PPT 中的圖形添加陰影效果

    這篇文章主要介紹了Java如何為 PPT 中的圖形添加陰影效果,幫助大家更好的利用java處理圖像,感興趣的朋友可以了解下
    2020-09-09
  • httpclient重定向之后獲取網(wǎng)址信息示例

    httpclient重定向之后獲取網(wǎng)址信息示例

    使用HttpClient進行127.0.0.1:8080地址的問題,然后該地址自動重定向127.0.0.1:8080/mobserver,如何獲取該地址呢?使用HttpContext,下面是示例
    2014-02-02
  • java 基于maven多模塊合并打包部署的操作過程

    java 基于maven多模塊合并打包部署的操作過程

    這篇文章主要介紹了java 基于maven多模塊合并打包部署的操作過程,本文通過實例代碼圖文相結合給大家介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • Java實現(xiàn)數(shù)據(jù)庫圖片上傳功能詳解

    Java實現(xiàn)數(shù)據(jù)庫圖片上傳功能詳解

    這篇文章主要為大家詳細介紹了如何使用Java實現(xiàn)數(shù)據(jù)庫圖片上傳功能,包含從數(shù)據(jù)庫拿圖片傳遞前端渲染,感興趣的小伙伴可以跟隨小編一起學習一下
    2025-03-03
  • idea中不用git解除關聯(lián)的方式

    idea中不用git解除關聯(lián)的方式

    IntelliJ?IDEA是一款高效的Java編程環(huán)境,提供智能編碼輔助、J2EE、Ant等集成,支持本地和遠程調試,本文講述了如何在IDEA中解除版本控制和刪除.git文件夾,幫助開發(fā)者更好地管理項目設置和提升開發(fā)效率
    2024-10-10

最新評論