springboot集成mybatis-plus
mybatis-plus特性(可以看官网)
- 无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑
- 损耗小:启动即会自动注入基本 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、SQLServer2005、SQLServer 等多种数据库
- 内置性能分析插件:可输出 Sql 语句以及其执行时间,建议开发测试时启用该功能,能快速揪出慢查询
- 内置全局拦截插件:提供全表 delete 、 update 操作智能分析阻断,也可自定义拦截规则,预防误操作
我之所以用这个完全感觉这个很简便,代码写起来很简洁,除了查询(简单的查询还是可以的要是复杂的查询还是老老实实的创建个xml 文件吧),剩下的增删改,都可以用mybatis-plus 底层自带的语法去做这个事情
废话不多说直接撸代码
mybatis-plus 所需要的包
<dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.1.6</version> </dependency> <dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>1.3.1</version> </dependency> <dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><scope>runtime</scope> </dependency> <dependency><groupId>com.baomidou</groupId><artifactId>mybatisplus-spring-boot-starter</artifactId><version>1.0.5</version> </dependency> <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus</artifactId><version>2.3.3</version> </dependency>
application.properties 配置一下数据库连接 和mybatis -plus 一些配置 server.port=8090logging.config=classpath:log4j2.xml# 数据库配置 spring.datasource.url=jdbc:mysql://127.0.0.1:3306/tom?serverTimezone=UTC&useSSL=false&allowPublicKeyRetrieval=true spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver# MyBatis 配置 mybatis-plus.mapper-locations=classpath:/mybatis/*Mapper.xml mybatis-plus.global-config.id-type=2 mybatis-plus.global-config.field-strategy=2 mybatis-plus.global-config.db-column-underline=true mybatis-plus.global-config.refresh-mapper=true mybatis-plus.global-config.logic-delete-value=0 mybatis-plus.global-config.logic-not-delete-value=1 mybatis-plus.global-config.sql-injector=com.baomidou.mybatisplus.mapper.LogicSqlInjector mybatis-plus.configuration.map-underscore-to-camel-case=true mybatis-plus.configuration.cache-enabled=false
项目的目录结构
springboot 项目启动处加上扫描 (这个用springboot 的相信都知道的)
实体类如下
注意:这里要用驼峰命名 我是懒省事 直接就一个单词
假如你数据库中字段是 student_name 这里你要写 studentName, 小驼峰 要和数据库对应上
mapper 层是要继承mybatis -plus 的basemapper
Service 层继承为我们提供的IService就行了
@Service
public interface StudentService extends IService<StudentDTO> {
}
ServiceImple
@Service public class StudenService Impl extends ServiceImpl<BaseMapper, StudentDTO> implements StudentService {}
这里我们业务层和mapper 层已经写完了
控制层
@RestController @RequestMapping("students/") public class TestController {@Autowiredprivate StudentMapper studentMapper;@PostMapping("/students")public IResponseStatus add(@RequestBody @Validated StudentDTO studentDTO){studentDTO.setName("测试的数据");studentMapper.insert(studentDTO);studentMapper.add("222");return CommonStatus.ADD_OK;}@PutMapping("/students")public IResponseStatus mpdify(@RequestBody StudentDTO studentDTO){studentMapper.updateById(studentDTO);return CommonStatus.UPDATE_OK;}@DeleteMapping("/students/{id}")public IResponseStatus del(@PathVariable String id){StudentDTO student=new StudentDTO();student.setId(id);studentMapper.deleteById(student);return CommonStatus.DELETE_OK;}}
有兴趣的同学可以看一下
假如我们的业务不涉及到查询 是不是或者简单的查询我们就不用创建xml 文件了 直接可以用底层自带的方法就可以完全解决问题了
springboot集成mybatis-plus相关推荐
- BindingException: Invalid bound statement (not found)问题排查:SpringBoot集成Mybatis重点分析...
重构代码,方法抛出异常:BindingException: Invalid bound statement (not found) 提示信息很明显:mybatis没有提供某方法 先不解释问题原因和排查 ...
- java整合mybatis,springboot集成mybatis
# springboot集成mybatis springboot基础mybatis还是很简单的,比之前springmvc集成mybatis要少很多配置,只要大家按照步骤一步一步来,几分钟就 能实现.具 ...
- springboot集成mybatis源码分析-mybatis的mapper执行查询时的流程(三)
springboot集成mybatis源码分析-mybatis的mapper执行查询时的流程(三) 例: package com.example.demo.service;import com.exa ...
- springboot集成mybatis源码分析-启动加载mybatis过程(二)
springboot集成mybatis源码分析-启动加载mybatis过程(二) 1.springboot项目最核心的就是自动加载配置,该功能则依赖的是一个注解@SpringBootApplicati ...
- springboot集成mybatis源码分析(一)
springboot集成mybatis源码分析(一) 本篇文章只是简单接受使用,具体源码解析请看后续文章 1.新建springboot项目,并导入mybatis的pom配置 配置数据库驱动和mybat ...
- SpringBoot集成Mybatis用法笔记
今天给大家整理SpringBoot集成Mybatis用法笔记.希望对大家能有所帮助! 搭建一个SpringBoot基础项目. 具体可以参考SpringBoot:搭建第一个Web程序 引入相关依赖 &l ...
- Java 捕获 mybatis异常_3 springboot集成mybatis和全局异常捕获
mybatis有两种方式,一种是基于XML,一种是基于注解 springboot集成mybatis 首先先创建表,这里都简化了 DROP TABLE IF EXISTS `user`; CREATE ...
- Springboot集成mybatis通用Mapper与分页插件PageHelper
Springboot集成mybatis通用Mapper与分页插件PageHelper 插件介绍 通用 Mapper 是一个可以实现任意 MyBatis 通用方法的框架,项目提供了常规的增删改查操作以及 ...
- 一个项目了解 SpringBoot 集成 MyBatis
SpringBoot 集成 MyBatis 创建项目 1.引入依赖 mybatis-spring-boot-starter 依赖 完整的 pom.xml 2.配置文件 加入mybatis配置 完整的配 ...
- SpringBoot教程(十一) | SpringBoot集成Mybatis
上一篇文章我们介绍了SpringBoot集成JdbcTemplate.简单体验了一下JdbcTemplate框架的用法,今天的内容比较重要,我们来介绍一下SpringBoot集成Mybatis的步骤. ...
最新文章
- 从底层吃透java内存模型(JMM)、volatile、CAS
- SpaceX「十一手」火箭创纪录,一天内两次升空,马斯克:飞100次才退役
- IDA分析shellcode导入windows结构体
- js php 时间格式化字符串,JS怎么实现字符串与日期的互相转换及日期的格式化
- binlog工具_MySQL5.6新增的参数binlog_row_image到底怎么设置-爱可生
- uC/GUI 在Cortex-M3 内核上的移植
- Python表示不甘心,汤姆大叔送书,Python抢书之毫秒级跟进--获取服务器时间
- 【文文殿下】APIO2019游记
- windows whistler系统安装
- http://www.csee.wvu.edu/~xinl/source.html 突然发现无法登陆,现备份内容以便后续查询
- TMC5160步进电机驱动芯片开发手记
- 达人评测 i9 13900H和i7 13700h差距 i913900H和i713700h选哪个
- matlab修复模糊图片论文,图像算法论文,关于运动模糊图像复原算法相关参考文献资料-免费论文范文...
- 华为鸿蒙遥控器,华为鸿蒙 2.0 开发者公测版 Beta 3更新 优酷鸿蒙版可让手机变遥控器...
- 2020年程序员技能展望:平均年薪5.4万美元,JavaScript与Python最受欢迎
- SpringBoot整合Javamail实现邮件发送
- mysql 货币显示_MySQL查询设置货币记录
- GD32F450创建工程模板
- 推荐系统入门学习简介(一)
- opencv 美白磨皮人脸检测
热门文章
- 工作手册:如何实施数据质量管理(上)
- win10屏幕亮度无法调节如何处理
- “自抗扰控制器”初探之InstaSPIN-MOTION
- 在编程的路上前行,便只顾风雨兼程——C++中段反思
- iOS 微信 音视频自动播放 原生接口WeixinJSBridge API(一些整理 小技巧)
- 高分系列卫星载荷参数
- “数学界的诺贝尔”公布2019年得主,首位女数学家获奖
- Android 12安装app失败,提示安装包解析异常
- 戴尔服务器序列号规则,解密:戴尔13G服务器命名规则和分类
- 产品真题笔试题目--牛客网