对于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);
相关推荐
一 乐7 小时前
疫苗发布和接种预约|基于Java+vue疫苗发布和接种预约系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·疫苗发布和接种预约系统系统
2301_780789667 小时前
高防cdn如何缓存网页静态资源
java·spring·web安全·缓存·kubernetes·ddos
小马爱打代码7 小时前
Spring源码 第十一篇:Spring 扩展点全解析 - 从容器启动到 Bean 生命周期的完整执行时序
java·后端·spring
RainCity8 小时前
Java Swing 自定义组件库分享(九)
java·笔记·后端
NE_STOP8 小时前
Docker--容器常用命令
java
摇滚侠8 小时前
MSYS2 Builds Hashes Cygwin Builds Hashes 区别
java
武子康8 小时前
Java-08 深入浅出 Mybatis 数据库多对多关系设计:中间表、映射与性能优化
java·后端·spring
鬼才血脉9 小时前
Idea使用Tomact运行项目,控制台输出中文乱码
tomcat·bug
无极低码9 小时前
wsdl转client使用wsimport,高版本openjdk不支持使用 JAX-WS
java
明夜之约9 小时前
Spring Cloud Gateway 深度解析:从路由原理到生产级网关实战
java·spring·spring cloud·gateway