中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MyBatisPlus如何實現分頁時排序

發布時間:2022-03-22 11:05:23 來源:億速云 閱讀:2236 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關MyBatisPlus如何實現分頁時排序,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

    簡介

    說明

    本文用示例介紹MyBtisPlus分頁時排序的方法。

    分頁時排序的方法

    • 后端OrderItems排序

    • 后端Wrapper排序

    • 前端指定排序

    排序涉及到的類

    排序涉及到Page類的List<OrderItem> orders;成員,OrderItem定義如下:

    public class OrderItem implements Serializable {
        private static final long serialVersionUID = 1L;
     
        //需要進行排序的字段
        private String column;
     
        // 是否正序排列,默認 true
        private boolean asc = true;
        ...
    }

    建庫建表

    DROP DATABASE IF EXISTS mp;
    CREATE DATABASE mp DEFAULT CHARACTER SET utf8;
    USE mp;
     
    DROP TABLE IF EXISTS `t_user`;
    SET NAMES utf8mb4;
     
    CREATE TABLE `t_user`
    (
        `id`           BIGINT(0) NOT NULL AUTO_INCREMENT,
        `user_name`    VARCHAR(64) NOT NULL COMMENT '用戶名(不能重復)',
        `nick_name`    VARCHAR(64) NULL COMMENT '昵稱(可以重復)',
        `email`        VARCHAR(64) COMMENT '郵箱',
        `create_time`  DATETIME(0) NULL DEFAULT CURRENT_TIMESTAMP COMMENT '創建時間',
        `update_time`  DATETIME(0) NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改時間',
        `deleted_flag` BIGINT(0) NOT NULL DEFAULT 0 COMMENT '0:未刪除 其他:已刪除',
        PRIMARY KEY (`id`) USING BTREE,
        UNIQUE KEY `index_user_name_deleted_flag` (`user_name`, `deleted_flag`),
        KEY `index_create_time`(`create_time`)
    ) ENGINE = InnoDB COMMENT = '用戶';
     
    INSERT INTO `t_user` VALUES (1, 'knife', '刀刃', 'abc@qq.com', '2021-01-23 09:33:36', '2021-01-23 09:33:36', 0);
    INSERT INTO `t_user` VALUES (2, 'sky', '天藍', '123@qq.com', '2021-01-24 18:12:21', '2021-01-24 18:12:21', 0);

    執行后的結果:

    MyBatisPlus如何實現分頁時排序

    依賴

    pom.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.3.12.RELEASE</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
        <groupId>com.example</groupId>
        <artifactId>MyBatis-Plus_Simple</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <name>MyBatis-Plus_Simple</name>
        <description>Demo project for Spring Boot</description>
     
        <properties>
            <java.version>1.8</java.version>
        </properties>
     
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
     
            <dependency>
                <groupId>com.baomidou</groupId>
                <artifactId>mybatis-plus-boot-starter</artifactId>
                <version>3.5.1</version>
            </dependency>
     
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
            </dependency>
     
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
            </dependency>
     
            <dependency>
                <groupId>org.projectlombok</groupId>
                <artifactId>lombok</artifactId>
            </dependency>
     
            <dependency>
                <groupId>com.github.xiaoymin</groupId>
                <artifactId>knife4j-spring-boot-starter</artifactId>
                <version>3.0.3</version>
            </dependency>
     
        </dependencies>
     
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>
     
    </project>

    配置

    application.yml

    spring:
      datasource:
        driver-class-name: com.mysql.cj.jdbc.Driver
        url: jdbc:mysql://127.0.0.1:3306/mp?characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
        username: root
        password: 222333
     
    #mybatis-plus配置控制臺打印完整帶參數SQL語句
    mybatis-plus:
      configuration:
        log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

    分頁插件的配置(必須)

    package com.example.demo.config;
     
    import com.baomidou.mybatisplus.annotation.DbType;
    import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
     
    @Configuration
    public class MyBatisPlusConfig {
     
        /**
         * 分頁插件
         */
        @Bean
        public MybatisPlusInterceptor mybatisPlusInterceptor() {
            MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
            interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
            return interceptor;
        }
    }

    代碼

    Entity

    package com.example.demo.user.entity;
     
    import com.baomidou.mybatisplus.annotation.IdType;
    import com.baomidou.mybatisplus.annotation.TableId;
    import com.baomidou.mybatisplus.annotation.TableLogic;
    import com.baomidou.mybatisplus.annotation.TableName;
    import com.baomidou.mybatisplus.extension.activerecord.Model;
    import lombok.Data;
     
    import java.time.LocalDateTime;
     
    @Data
    @TableName(value = "t_user")
    public class User {
        @TableId(value = "id", type = IdType.AUTO)
        private Long id;
     
        /**
         * 用戶名(不能重復)
         */
        private String userName;
     
        /**
         * 昵稱(可以重復)
         */
        private String nickName;
     
        /**
         * 郵箱
         */
        private String email;
     
        /**
         * 創建時間
         */
        private LocalDateTime createTime;
     
        /**
         * 修改時間
         */
        private LocalDateTime updateTime;
     
        /**
         * 0:未刪除 其他:已刪除
         */
        @TableLogic(delval = "id")
        private Long deletedFlag;
    }

    Service

    接口

    package com.example.demo.user.service;
     
    import com.baomidou.mybatisplus.extension.service.IService;
    import com.example.demo.user.entity.User;
     
    public interface UserService extends IService<User> {
    }

    實現

    package com.example.demo.user.service.impl;
     
    import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
    import com.example.demo.user.entity.User;
    import com.example.demo.user.mapper.UserMapper;
    import com.example.demo.user.service.UserService;
    import org.springframework.stereotype.Service;
     
    @Service
    public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
    }

    Controller

    package com.example.demo.user.controller;
     
    import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
    import com.baomidou.mybatisplus.core.metadata.IPage;
    import com.baomidou.mybatisplus.core.metadata.OrderItem;
    import com.baomidou.mybatisplus.core.toolkit.Wrappers;
    import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
    import com.example.demo.user.entity.User;
    import com.example.demo.user.service.UserService;
    import io.swagger.annotations.Api;
    import io.swagger.annotations.ApiOperation;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RestController;
     
    import java.util.List;
     
    @Api(tags = "排序")
    @RestController
    @RequestMapping("sort")
    public class SortController {
     
        @Autowired
        private UserService userService;
     
        @ApiOperation("默認順序")
        @GetMapping("defaultOrder")
        public IPage<User> defaultOrder(Page<User> page) {
            return userService.page(page);
        }
     
        @ApiOperation("通過orderItems")
        @GetMapping("orderItems")
        public IPage<User> orderItems(Page<User> page) {
            page.addOrder(OrderItem.desc("create_time"));
            // 可以指定多列。比如下邊這個:按create_time排序,若create_time相同,則按id排序
            // page.addOrder(OrderItem.desc("create_time"), OrderItem.asc("id"));
            return userService.page(page);
        }
     
        @ApiOperation("通過wrapper")
        @GetMapping("wrapper")
        public IPage<User> wrapper(Page<User> page) {
            LambdaQueryWrapper<User> queryWrapper = Wrappers.<User>lambdaQuery();
            // 按create_time排序,若create_time相同,則按id排序
            queryWrapper.orderByDesc(User::getCreateTime);
            queryWrapper.orderByAsc(User::getId);
            return userService.page(page, queryWrapper);
        }
     
        @ApiOperation("前端指定順序")
        @GetMapping("byFrontEnd")
        public IPage<User> byFrontEnd(Page<User> page) {
            return userService.page(page);
        }
    }

    測試

    訪問Knife4j頁面:http://localhost:8080/doc.html

    MyBatisPlus如何實現分頁時排序

    1.不指定順序

    本處前端不傳任何參數進行的測試。

    MyBatisPlus如何實現分頁時排序

    2.后端OrderItem排序(create_time倒序)

    本處前端不傳任何參數進行的測試。

    MyBatisPlus如何實現分頁時排序

    3.后端Wrapper排序(create_time倒序,id升序)

    本處前端不傳任何參數進行的測試。

    MyBatisPlus如何實現分頁時排序

    4.前端指定排序(create_time倒序)

    前端指定orders[0].asc和orders[0].column

    MyBatisPlus如何實現分頁時排序

    結果:

    MyBatisPlus如何實現分頁時排序

    關于“MyBatisPlus如何實現分頁時排序”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    中牟县| 温泉县| 曲靖市| 邻水| 含山县| 宜川县| 新干县| 武义县| 中卫市| 邵武市| 安岳县| 兰坪| 平遥县| 天全县| 盐津县| 绥江县| 宜兰县| 沙湾县| 马边| 肃南| 海门市| 南安市| 木兰县| 锡林浩特市| 定边县| 措勤县| 邓州市| 浙江省| 敦煌市| 高安市| 曲阳县| 邛崃市| 万全县| 绿春县| 赤城县| 文昌市| 霍州市| 潍坊市| 皮山县| 宁武县| 莆田市|