对于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);
相关推荐
永远有缘5 分钟前
四种编程语言常用函数对比表
java·开发语言·c++·python
C++_girl5 分钟前
c++、java/python语言有什么区别?为什么c++更快?
java·开发语言·c++
YZD082616 分钟前
Docker 二进制包的下载与安装
java·docker·eureka
脸大是真的好~22 分钟前
黑马JAVA+AI 加强07 Stream流-可变参数
java·开发语言
悟能不能悟29 分钟前
mybatis的sql中,如果一个条件column=#{column},column的值为null时,会不会匹配出column is null 的记录
sql·tomcat·mybatis
浮游本尊42 分钟前
Java学习第27天 - 微服务安全与云原生架构
java
m0_7369270442 分钟前
使用 Python 将 PowerPoint 转换为 Word 文档
java·开发语言·后端·职场和发展·c#
稚辉君.MCA_P8_Java1 小时前
Java 基本数据类型 - 四类八种
java·linux·后端·mysql·架构
裸奔在上海1 小时前
使用Java做URL短连接还原长链接获取参数
java·开发语言·程序人生·spring
爱吃烤鸡翅的酸菜鱼1 小时前
如何掌握【Java】 IO/NIO设计模式?工厂/适配器/装饰器/观察者模式全解析
java·开发语言·后端·设计模式·nio