ruoyi-plus-server(一):引入Mybatis-Plus
背景:著名开源管理系统ruoyi-vue是基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统(https://gitee.com/y_project/RuoYi-Vue)
需求:站在巨人的肩膀上打造一个更符合自己使用习惯的管理系统
源码:https://gitee.com/baohaipeng/ruoyi-plus-server
方法:
一、下载资源,项目跑起来
1、下载地址:https://gitee.com/y_project/RuoYi-Vue.git
2、按照官方提供的sql文件,创建数据库
3、打开ruoyi项目修改数据库连接(application-druid.yml),修改redis等其他配置后,启动无误代表项目源码正常、数据库正常
4、为示区别,修改包名(com.ruoyi——>com.bhp.ruoyiplus),此时不能直接启动,还需修改以下两处
①typeAliasesPackage
②ApplicationConfig
备注:可以在这里直接改为com.bhp.ruoyiplus.project.**.mapper,也可以把这里的@MapperScan删掉,加在启动类。由于后期我想将该包发布成依赖供其他项目使用,为避免冲突,我选择删掉该处注解,在启动类上进行扫描
二、引入lombok,对象代码更干净
1、版本:1.16.10
2、依赖
- <dependency>
- <groupId>org.projectlombok</groupId>
- <artifactId>lombok</artifactId>
- <version>1.16.10</version>
- </dependency>
三、引入MP,sql操作更简便
1、官方文档:https://mp.baomidou.com/
2、版本:3.3.0
3、依赖
- <dependency>
- <groupId>com.baomidou</groupId>
- <artifactId>mybatis-plus-boot-starter</artifactId>
- <version>3.3.</version>
- </dependency>
- <dependency>
- <groupId>com.baomidou</groupId>
- <artifactId>mybatis-plus-extension</artifactId>
- <version>3.3.</version>
- </dependency>
四、project目录下新建demo模块
1、数据库脚本
- CREATE TABLE `demo` (
- `id` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
- `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
- `des` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
- PRIMARY KEY (`id`) USING BTREE
- ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
- INSERT INTO `demo` VALUES ('', 'demomom', '好');
2、目录结构
3、模块代码
①Demo
- import com.baomidou.mybatisplus.annotation.IdType;
- import com.baomidou.mybatisplus.annotation.TableField;
- import com.baomidou.mybatisplus.annotation.TableId;
- import com.baomidou.mybatisplus.annotation.TableName;
- import lombok.Data;
- /**
- * @ClassName Demo
- * @Description TODO
- * @Author 北海派
- * @Date 2020/5/18 19:24
- * @Version 1.0
- **/
- @Data
- @TableName("demo")
- public class Demo{
- @TableId(value = "id", type = IdType.UUID)
- private String id;
- @TableField("name")
- private String name;
- @TableField("des")
- private String des;
- }
②DemoMapper
- import com.baomidou.mybatisplus.core.mapper.BaseMapper;
- import com.bhp.ruoyiplus.project.demo.domain.Demo;
- /**
- * @ClassName DemoMapper
- * @Description TODO
- * @Author 北海派
- * @Date 2020/5/18 19:30
- * @Version 1.0
- **/
- public interface DemoMapper extends BaseMapper<Demo> {
- }
③DemoService
- import com.baomidou.mybatisplus.extension.service.IService;
- import com.bhp.ruoyiplus.project.demo.domain.Demo;
- /**
- * @ClassName DemoService
- * @Description TODO
- * @Author 北海派
- * @Date 2020/5/18 19:32
- * @Version 1.0
- **/
- public interface DemoService extends IService<Demo> {
- }
④DemoServiceImpl
- import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
- import com.bhp.ruoyiplus.project.demo.domain.Demo;
- import com.bhp.ruoyiplus.project.demo.mapper.DemoMapper;
- import com.bhp.ruoyiplus.project.demo.service.DemoService;
- import org.springframework.stereotype.Service;
- /**
- * @ClassName DemoServiceImpl
- * @Description TODO
- * @Author 北海派
- * @Date 2020/5/18 19:32
- * @Version 1.0
- **/
- @Service
- public class DemoServiceImpl extends ServiceImpl<DemoMapper, Demo> implements DemoService {
- }
⑤DemoController
- import com.bhp.ruoyiplus.framework.web.controller.BaseController;
- import com.bhp.ruoyiplus.project.demo.domain.Demo;
- import com.bhp.ruoyiplus.project.demo.service.DemoService;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.web.bind.annotation.GetMapping;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RestController;
- /**
- * @ClassName DemoController
- * @Description TODO
- * @Author 北海派
- * @Date 2020/5/18 19:22
- * @Version 1.0
- **/
- @RestController
- @RequestMapping("/demo")
- public class DemoController extends BaseController {
- @Autowired
- private DemoService demoService;
- @GetMapping()
- public Demo get(){
- Demo demo = demoService.getById("1");
- return demo;
- }
- }
4、重启项目,用Postman获取验证码、登录获取token、访问接口,报如下错误
原因:项目使用的mybatis及其相关配置MP中自带的mybatis冲突,需要排除项目中的依赖及配置
①修改POM文件,删除如下依赖
②修改配置文件,删除application.yml中的mybatis配置,增加MP配置
- # MyBatis配置
- #mybatis:
- # # 搜索指定包别名
- # typeAliasesPackage: com.bhp.ruoyiplus.project.**.domain
- # # 配置mapper的扫描,找到所有的mapper.xml映射文件
- # mapperLocations: classpath*:mybatis/**/*Mapper.xml
- # # 加载全局的配置文件
- # configLocation: classpath:mybatis/mybatis-config.xml
- # MyBatis-Plus配置
- mybatis-plus:
- mapper-locations: classpath*:mybatis/**/*Mapper.xml
- #实体扫描
- typeAliasesPackage: com.bhp.ruoyiplus.project.**.domain
③删除MybatisConfig配置类
④重启项目,再次访问接口,响应正常
⑤修改DemoController,测试框架统一响应,与框架分页响应是否正常,经测试接口均正常
- import com.bhp.ruoyiplus.framework.web.controller.BaseController;
- import com.bhp.ruoyiplus.framework.web.domain.AjaxResult;
- import com.bhp.ruoyiplus.framework.web.page.TableDataInfo;
- import com.bhp.ruoyiplus.project.demo.domain.Demo;
- import com.bhp.ruoyiplus.project.demo.service.DemoService;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.web.bind.annotation.GetMapping;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RestController;
- /**
- * @ClassName DemoController
- * @Description TODO
- * @Author 北海派
- * @Date 2020/5/18 19:22
- * @Version 1.0
- **/
- @RestController
- @RequestMapping("/demo")
- public class DemoController extends BaseController {
- @Autowired
- private DemoService demoService;
- @GetMapping()
- public AjaxResult get() {
- Demo demo = demoService.getById("1");
- if (null==demo){
- return AjaxResult.error("无数据");
- }
- return AjaxResult.success(demo);
- }
- @GetMapping("/list")
- public TableDataInfo getList() {
- startPage();
- return getDataTable(demoService.list());
- }
- }
ruoyi-plus-server(一):引入Mybatis-Plus的更多相关文章
- springboot引入mybatis遇到的坑
前边分享了springboot项目的创建及springboot项目的默认配置文件等,想温习的小伙伴可移步至文章末尾阅读,感谢.今天来分享下springboot引入mybatis框架的步骤,有小伙伴 ...
- sring引入mybatis
1.首先框架结构是这样的(jar包还是要导的) 2.web.xml和springMVC-servlet.xml未作任何新的配置,这里简单贴一下代码: <?xml version="1. ...
- 在eclipse中引入mybatis和spring的约束文件
eclipse中引入mybatis约束文件步骤: 首先: config的key值 http://mybatis.org/dtd/mybatis-3-config.dtd mapper的key值 htt ...
- spring boot使用注解的方式引入mybatis的SqlSessionDaoSupport
出现这个问题, 说明一点, 我对spring的注解方式的配置只是知道一个皮毛. 没有深入理解. 有时间要把这部分充充电 package com.zhike.qizhi.common.dao; impo ...
- server.xml引入子文件配置(tomcat虚拟主机)
在配置tomcat虚拟主机时候,如何每一个虚拟主机写成单独文件,server.xml包含这些子文件? 如以下<OneinStack>中,添加JAVA环境虚拟主机后tomcat配置文件详情: ...
- server.xml引入子文件配置(tomcat虚拟主机)[转]
在配置tomcat虚拟主机时候,如何每一个虚拟主机写成单独文件,server.xml包含这些子文件? 如以下<OneinStack>中,添加JAVA环境虚拟主机后tomcat配置文件详情: ...
- Spring Boot 集成 MyBatis和 SQL Server实践
概 述 Spring Boot工程集成 MyBatis来实现 MySQL访问的示例我们见过很多,而最近用到了微软的 SQL Server数据库,于是本文则给出一个完整的 Spring Boot + M ...
- MyBatis 源码分析——介绍
笔者第一次接触跟MyBatis框架是在2009年未的时候.不过那个时候的他并不叫MyBatis,而是叫IBatis.2010年的时候改为现在的名字--MyBatis.这几年过去了,对于笔者来讲有一点陌 ...
- 玩转 SSH(六):SpringMVC + MyBatis 架构搭建(注解版)
一.创建 SSMVCAnnoDemo 项目 点击菜单,选择“File -> New Project” 创建新项目.选择使用 archetype 中的 maven-webapp 模版创建. 输入对 ...
- IDEA下使用maven构建web项目(SpringMVC+Mybatis整合)
需求背景:由于最近总是接到一些需求,需要配合前端团队快速建设移动端UI应用或web应用及后台业务逻辑支撑的需求,若每次都复用之前复杂业务应用的项目代码,总会携带很多暂时不会用到的功能或组件,这样的初始 ...
随机推荐
- 如何快速地恢复你的win10
win10清单 这份List不会介绍如何安装系统,而是当面对一个新系统,如何最快的搭建,或者说恢复到一个生产力环境. 必备习惯 备份软件安装包和常用内容上云是高效恢复的两点关键. 备份软件安装包 我的 ...
- Centos史上新版最详细步骤-Linux无脑命令式oracle11g静默安装
1. 关闭selinux 1.1 sed -i "s/SELINUX=enforcing/SELINUX=disabled/" /etc/selinux/config 1.2 或者 ...
- Asp.Net Core 3.1学习-依赖注入、服务生命周期(6)
1.前言 面向对象设计(OOD)里有一个重要的思想就是依赖倒置原则(DIP),并由该原则牵引出依赖注入(DI).控制反转(IOC)及其容器等概念.在学习Core依赖注入.服务生命周期之前,下面让我们先 ...
- Linux网络服务第七章DNS域名解析服务
端口:53 一.DNS服务器 正向解析:根据域名查IP地址,即将指定的域名解析为相对应的IP地址.域名的正向解析是DNS服务器最基本的功能,也是最常用的功能. 反向解析:根据IP地址查域名,即将指定的 ...
- String、String[]、ArrayList<String>之间的转换
1. ArrayList<String> 转换为 String[]: ArrayList<String> list = new ArrayList<>(); li ...
- LaTex中文article模板(支持代码、数学、TikZ)
代码 请使用XeLatex编译 main.tex \documentclass{article} \usepackage{ctex} %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% ...
- redis- info调优入门-《每日五分钟搞定大数据》
本文根据redis的info命令查看redis的内存使用情况以及state状态,来观察redis的运行情况以及需要作出的相应优化. info 1.memory used_memory:13409011 ...
- Java中的集合Queue
2019独角兽企业重金招聘Python工程师标准>>> package com.zhaogang.test; import org.junit.Test; import java.u ...
- js特效:鼠标滑过图片时切换为动图
效果展示 事前准备 一张普通的静态图+与其对应的gif图. 实现思路 获取图片的src,改变其后缀,使其变成与之对应的gif图片.(很简单有木有= =) 具体实现 编写html代码 <div c ...
- 使用cpplint检测代码规范
0. cpplint - python脚本, google使用它作为自己的C++代码规范检查工具: 1. 安装 方法一: $sudo apt-get install python-pip $pip i ...