对于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);
相关推荐
珹洺13 小时前
Java-Spring入门指南(二十一)Thymeleaf 视图解析器
java·开发语言·spring
源码集结号13 小时前
一套智慧工地云平台源码,支持监管端、项目管理端,Java+Spring Cloud +UniApp +MySql技术开发
java·mysql·spring cloud·uni-app·源码·智慧工地·成品系统
EnCi Zheng13 小时前
Spring Security 最简配置完全指南-从入门到精通前后端分离安全配置
java·安全·spring
程序员小假13 小时前
为什么这些 SQL 语句逻辑相同,性能却差异巨大?
java·后端
泉城老铁14 小时前
springboot实现对接poi 导出excel折线图
java·spring boot·后端
金銀銅鐵14 小时前
[Java] 如何自动生成简单的 Mermaid 类图
java·后端
纵横八荒15 小时前
Java基础加强13-集合框架、Stream流
java·开发语言
稚辉君.MCA_P8_Java15 小时前
kafka解决了什么问题?mmap 和sendfile
java·spring boot·分布式·kafka·kubernetes
乄bluefox15 小时前
保姆级docker部署nacos集群
java·docker·容器
欣然~15 小时前
百度地图收藏地址提取与格式转换工具 说明文档
java·开发语言·dubbo