springboot-mybatisplus-demo

mapper service impl

复制代码
package com.example.demo.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.demo.entity.User;
import org.apache.ibatis.annotations.Mapper;

@Mapper
public interface UserMapper extends BaseMapper<User> {

}

public interface UserService extends IService<User> {

}

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {

}

controller

java 复制代码
package com.example.demo.controller;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.example.demo.entity.Result;
import com.example.demo.entity.User;
import com.example.demo.service.UserService;
import lombok.extern.slf4j.Slf4j;
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.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import java.time.LocalDateTime;
import java.util.List;
import java.util.WeakHashMap;

@RestController
@Slf4j
@RequestMapping("/user")
public class UserController extends BaseController {
    @Autowired
    private UserService userService;

    @GetMapping
    public Result index() {
        return Result.success(userService.list());
    }

    @GetMapping("/page")
    public Result page(@RequestParam(defaultValue = "1", required = false) Integer page,
                       @RequestParam(defaultValue = "10", required = false) Integer size) {

        Page<User> page1 = Page.of(page, size);
        page1 = userService.page(page1);
        log.info("page: {}", page1);
        return Result.success(page1);
    }

    @GetMapping("/t1")
    public Result t1() {
        User user = new User();
        user.setUsername("tom");

        List<User> list = userService.list(Wrappers.<User>lambdaQuery().ge(User::getId, 138));

        userService.update(user, Wrappers.<User>lambdaUpdate().ge(User::getId, 138));

        QueryWrapper<User> queryWrapper = new QueryWrapper<>();
        queryWrapper.select("now(),id,username");
        System.out.println(queryWrapper.getSqlSelect());

        userService.list(queryWrapper);

        return Result.success( list);
    }
}

需要增加配置类

java 复制代码
package com.example.demo.config;

import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class MybatisPlusConfig {

    /**
     * 添加分页插件
     */
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); // 如果配置多个插件, 切记分页最后添加
        // 如果有多数据源可以不配具体类型, 否则都建议配上具体的 DbType
        return interceptor;
    }
}

源码:https://gitee.com/fanruitian/springboot-mybatis-demo

相关推荐
倔强菜鸟2 小时前
2025.11.21-GO语言入门(一)
开发语言·后端·golang
IT_陈寒2 小时前
【SpringBoot 3.2实战】10倍性能优化的5个冷门技巧,90%开发者都不知道!
前端·人工智能·后端
风生u2 小时前
Go的并发(协程)
开发语言·后端·golang
计算机毕设指导62 小时前
基于微信小程序的心理咨询预约系统【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven
问道飞鱼2 小时前
【开发语言】Rust语言介绍
开发语言·后端·rust
IMPYLH2 小时前
Lua 的 setmetatable 函数
开发语言·笔记·后端·游戏引擎·lua
风象南2 小时前
Spring Boot实现文件访问安全
后端
Victor3562 小时前
Redis(170)如何使用Redis实现分布式限流?
后端
Victor3562 小时前
Redis(171)如何使用Redis实现分布式事务?
后端