
MyBatis--02-- MybatisPlus介绍
1 引入jar包(官网https://baomidou.com/)
发布日期:2021-05-04 19:53:59
浏览次数:25
分类:技术文章
本文共 5428 字,大约阅读时间需要 18 分钟。
MybatisPlus介绍
url地址: https://baomidou.com
MyBatis-Plus(简称 MP)是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。
ORM
对象关系映射(英语:Object Relational Mapping,简称ORM,或O/RM,或O/R mapping),是一种程序设计技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。从效果上说,它其实是创建了一个可在编程语言里使用的“虚拟对象数据库”。如今已有很多免费和付费的ORM产品,而有些程序员更倾向于创建自己的ORM工具。
实质: 对象与数据库中表完成映射
分析:- 对象与表一一映射.
- 对象中的属性与表中的字段一一映射.
实质: 以对象的方式操作数据库.
说明 : Mybatis满足ORM对象映射的要求,但是Mybatis是一种半自动化的ORM映射框架
MP特性
无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑
损耗小:启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象操作 强大的 CRUD 操作:内置通用 Mapper、通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作,更有强大的条件构造器,满足各类使用需求 支持 Lambda 形式调用:通过 Lambda 表达式,方便的编写各类查询条件,无需再担心字段写错 支持主键自动生成:支持多达 4 种主键策略(内含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解决主键问题 支持 ActiveRecord 模式:支持 ActiveRecord 形式调用,实体类只需继承 Model 类即可进行强大的 CRUD 操作 支持自定义全局通用操作:支持全局通用方法注入( Write once, use anywhere ) 内置代码生成器:采用代码或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 层代码,支持模板引擎,更有超多自定义配置等您来使用 内置分页插件:基于 MyBatis 物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于普通 List 查询 分页插件支持多种数据库:支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多种数据库 内置性能分析插件:可输出 Sql 语句以及其执行时间,建议开发测试时启用该功能,能快速揪出慢查询 内置全局拦截插件:提供全表 delete 、 update 操作智能分析阻断,也可自定义拦截规则,预防误操作MP入门案例
1 引入jar包(官网https://baomidou.com/)
com.baomidou mybatis-plus-boot-starter 3.2.0
2 编辑POJO对象
@Data@Accessors(chain = true)@TableName //("user") //1.将对象与表 进行一对一关联public class User implements Serializable { @TableId(type = IdType.AUTO) //主键的信息 设定自增 private Integer Id; //@TableField(value = "name") //如果字段名称与属性的名称一致(包含驼峰规则),可以省略不写 private String name; private Integer age; private String sex;
编辑Mapper接口
继承BaseMapper<>接口

4修改YML映射文件
5 入门案例测试
@Test public void testSelect01(){ ListuserList = userDao.selectList(null); System.out.println(userList); }
MP API介绍
BaseMapper

查询 select
@Test public void testSelect01(){ ListuserList = userDao.selectList(null); System.out.println(userList); } /** * 业务: 查询id=11的用户信息 主键... */ @Test public void testSelect02(){ User user = userDao.selectById(11); System.out.println(user); } /** * 业务: 查询name属性为"小乔"的数据 * sql: select * from user where name="小乔"; * 对象的方式 > sql方式 */ @Test public void testSelect03(){ //条件构造器 QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.eq("name", "小乔"); List userList = userDao.selectList(queryWrapper); System.out.println(userList); } /** * 业务: 查询name属性为"小乔"的数据 并且 age >=18岁 * sql: select * from user where name="小乔" and age>=18; * * 大于 > gt| 小于 < lt | * 大于等于 >= ge | 小于等于 le */ @Test public void testSelect04(){ //条件构造器 QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.eq("name", "小乔") .ge("age", 18); List userList = userDao.selectList(queryWrapper); System.out.println(userList); } /** * 业务: 查询name中包含 "精"的用户,并且sex为女 * 业务: 查询name中包含 以精结尾的数据,并且sex为女 * sql: select * from user where name like "%精%" and sex="女"; */ @Test public void testSelect05(){ //条件构造器 QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.likeLeft("name", "精") .eq("sex", "女"); List userList = userDao.selectList(queryWrapper); System.out.println(userList); } /** * 需求: 查询user表中的数据 要求按照年龄降序排列,如果年龄相同按照id降序排列 */ @Test public void testSelect06(){ QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.orderByDesc("age","id"); List userList = userDao.selectList(queryWrapper); System.out.println(userList); } /** * 需求: 查询name属性为null的数据. * where name is null */ @Test public void testSelect07(){ QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.isNull("name"); List userList = userDao.selectList(queryWrapper); System.out.println(userList); } /** * 查询name="小乔" age=17 性别=女的用户 * 如果传递的是对象.会根据对象中不为null的属性充当where条件. */ @Test public void testSelect08(){ User user = new User(); user.setName("小乔").setAge(17).setSex("女"); QueryWrapper queryWrapper = new QueryWrapper<>(user); List userList = userDao.selectList(queryWrapper); System.out.println(userList); } /** * 查询id=1,3,5,10数据. * sql: select * from user where id in (1,3,5,10) */ @Test public void testSelect09(){ //转化时,注意使用对象的类型 Integer[] ids = { 1,3,5,10}; List idList = Arrays.asList(ids); List userList = userDao.selectBatchIds(idList); System.out.println(userList); } @Test public void testInsert(){ User user = new User(); user.setName("特朗普").setAge(70).setSex("男"); userDao.insert(user); }
删除 delete
/** * 删除name=null的数据,或者name="特朗普" */ @Test public void testDelete(){ QueryWrapperqueryWrapper = new QueryWrapper<>(); queryWrapper.isNull("name") .or() .eq("name", "特朗普"); userDao.delete(queryWrapper); }
更新 Update
/** * 案例1: 将id=1的数据的年龄改为8000岁. * sql1: update user set age=8000 where id=1; * 案例2: 要求将name="黑熊精" age=5500. * sql2: update user set age=5500 where name="黑熊精"; */ @Test public void testUpdate(){ User user = new User(); user.setId(1); //主键充当where条件 user.setAge(8000); userDao.updateById(user); //参数说明 1.实体对象 封装set条件的值 // 2.更新条件构造器 User temp = new User(); temp.setAge(5500); UpdateWrapperupdateWrapper = new UpdateWrapper<>(); updateWrapper.eq("name", "黑熊精"); userDao.update(temp,updateWrapper); }
插入 insert
@Test public void test09(){ User user = new User(); user.setName("瑶瑶"); user.setAge(88); user.setSex("女"); userDao.insert(user); }
发表评论
最新留言
很好
[***.229.124.182]2025年04月03日 12时48分56秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
Thinkphp6.0+vue个人虚拟物品发卡网站源码
2019-03-03
游戏服务端开发之基础概念扫盲篇
2019-03-03
手游服务端框架之关于玩家数据的解决方案
2019-03-03
游戏服务端框架之网关
2019-03-03
游戏服务端框架之模仿SpringMvc实现消息路由
2019-03-03
动态摇动吊牌自适应网站404页面源码
2019-03-03
炫酷文字消失动画网站404页面源码
2019-03-03
EMLOG模板山河网站主题分享
2019-03-03
2020年,51Talk求一个盈利的机会
2019-03-03
2019数字音乐市场年度回顾,QQ音乐全面领先
2019-03-03
迅雷新财报背后:下载一哥到艰难求生
2019-03-03
腾讯终于要杀入电商直播了
2019-03-03
花1亿扶持优质红人,如涵推动网红经济出圈之路有何深意?
2019-03-03
AMD、Intel、NVIDIA芯片三巨头内战
2019-03-03
开门红财报下,贝壳找房的春天依然有点冷
2019-03-03
虾米逝去:透视在线音乐的下一场战争
2019-03-03
抢滩抖音、B站,快手港股IPO进程加速
2019-03-03
智能穿戴的结局依然充满悬念
2019-03-03
Linux中的虚拟内存机制和内存映射
2019-03-03
Android系统启动系列5 SystemServer进程下
2019-03-03