对于mybatis和mybatisplus的选择

对于mybatis和mybatisplus的选择

  • [1. 问题](#1. 问题)
  • [2. MP单表操作](#2. MP单表操作)
    • [2.1 单表普通查询](#2.1 单表普通查询)
    • [2.2 单表分页查询](#2.2 单表分页查询)
  • [3. mybatis多表操作](#3. mybatis多表操作)
    • [3.1 多表普通查询](#3.1 多表普通查询)
    • [3.2 多表分页查询](#3.2 多表分页查询)

1. 问题

mybatis 和 mybatisplus作为当下主流的持久层框架,各有优劣势。依据个人经验:mybatis可以定制化输出数据库操作,但是却需要手写sql和mapper以及service中的方法;mybatisplus虽然少了手写sql和一些mapper以及service方法,但是对于多表操作的便捷性还是有很大不足。按照我的习惯,更偏向于mybatisplus+mybatis结合使用,在单表操作时利用MP提高效率;在多表操作时,利用mybatis。


2. MP单表操作

mp的一些常规操作

2.1 单表普通查询

java 复制代码
QueryWrapper<UserInfo> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("age", 20);
List<UserInfo> list = userInfoMapper.selectList(queryWrapper );

2.2 单表分页查询

java 复制代码
// 条件查询
LambdaQueryWrapper<UserInfo> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserInfo::getAge, 20);
// 分页对象
Page<UserInfo> queryPage = new Page<>(page, limit);
// 分页查询
IPage<UserInfo> iPage = userInfoMapper.selectPage(queryPage , queryWrapper);
// 数据总数
Long total = iPage.getTotal();
// 集合数据
List<UserInfo> list = iPage.getRecords();

3. mybatis多表操作

3.1 多表普通查询

java 复制代码
List<Country> list = countryMapper.selectAll();

3.2 多表分页查询

java 复制代码
//获取第1页,10条内容,默认查询总数count
PageHelper.startPage(1, 10);
List<Country> list = countryMapper.selectAll();
//用PageInfo对结果进行包装
PageInfo page = new PageInfo(list);
相关推荐
环流_20 小时前
nacos环境隔离
java·服务器·前端
芋只因20 小时前
天机学堂学习笔记
java·笔记·学习
摇滚侠20 小时前
Spring 面试题 真正的 offer 偏方 Java 基础 Java 高级
java·后端·spring
凯瑟琳.奥古斯特20 小时前
IP组播跨子网传输核心技术解析
java·开发语言·网络·网络协议·职场和发展
若水不如远方20 小时前
Java JSON 序列化原理与实战问题总结
java
hexu_blog20 小时前
前端vue后端java+springboot如何实现pdf,word,excel之间的相互转换
java·前端·vue.js·spring boot·文档转换
贺国亚20 小时前
synchronized- 并发
java·面试
martian66520 小时前
在 IntelliJ IDEA 中安装、配置 Claude Code 及解决连接错误完全指南
java·ide·intellij-idea
lalala_Zou20 小时前
某大厂后端一面
java·开发语言
爱笑的源码基地20 小时前
拿来即用:基于Spring Cloud+UniApp的智慧工地源码,架构清晰易扩展
java·云计算·源码·智慧工地·程序·开箱即用·数字工地