MyBatis-Plus及多数据源入门教程

开发环境配置

JDK 1.8、Maven 3.8.8、 IDEA CE 2023.2、MySQL 8.0.34

框架介绍

MyBatis-Plus(简称 MP)是一个 MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。MyBatis 是一款非常优秀的开源框架,用来简化数据库应用程序的开发,使开发人员能够专注于应用程序逻辑,而不必关注数据库和 SQL 语句细节

框架依赖

在 pom 文件中添加 MyBatis-Plus 、MySQL 依赖,如下:

<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.1</version></dependency><dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId><version>8.0.32</version><scope>compile</scope></dependency></dependencies>

开始使用

enity 层定义数据库实体类:
package com.zdxlz.lwq.enity;import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;@TableName("grade")
public class Grade {@TableIdprivate  int id;@TableField("p_id")private String p_id;@TableField("score")private int score;@TableField("level")private String level;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getP_id() {return p_id;}public void setP_id(String p_id) {this.p_id = p_id;}public int getScore() {return score;}public void setScore(int score) {this.score = score;}public String getLevel() {return level;}public void setLevel(String level) {this.level = level;}
}
注解详解

@TableName 表名注解,标识实体类对应的表

@TableId 主键注解,标识实体类主键字段

@TableField 字段注解,标识实体类非主键字段

更多注解参阅:注解 | MyBatis-Plus

重要说明:实体类所对应的数据库及表、字段应提前在 MySQL 中创建完毕,且名称、字段类型完全一致,并在 application.yml 中正确配置数据库信息,如下:

spring:datasource:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://192.168.22.82:3306/my_db?useUnicode=true&useSSL=falseusername: rootpassword: 123456
创建 Mapper

Mapper 是 MyBatis 中最重要的文件,文件中包含一组 SQL 语句(例如查询、添加、删除、修改),这些语句称为映射语句或者 SQL 映射语句。一个完整的 Mapper 映射器有Java 接口和 XML 文件(或注解)共同组成,它的作用包括:

  • 定义参数类型

  • 配置缓存

  • 提供 SQL 语句和动态 SQL

  • 定义查询结果和 POJO 的映射关系

具体介绍及使用可参阅:【Java ee】MyBatis核心配置——Mapper元素_mybatis映射文件中mapper元素_鸡兄长高了的博客-CSDN博客

为了简化开发,我们使用 MyBatis-Plus 提供的 Mapper 及一系列 SQL 接口,Mapper 实现如下:

package com.zdxlz.lwq.mapper;import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.zdxlz.lwq.enity.Grade;
import org.apache.ibatis.annotations.Mapper;@Mapper
public interface GradeMapper extends BaseMapper<Grade> {}

Mapper 开发完毕后,需要在 Application 中增加 @MapperScan 注解,@MapperScan 注解用于扫描 Mapper 接口,并将其实例化后交给 Spring 容器管理,使得可以在其他组件中使用这些 Mapper 接口的实现类。如下:

@SpringBootApplication
@MapperScan("com.zdxlz.lwq.mapper")
public class SpringBootDemoApplication {public static void main(String[] args) {SpringApplication.run(SpringBootDemoApplication.class,args);}
}
创建 Service

符合 Spring 开发 MVC 规范,创建 Service 层,在该层进行业务逻辑的具体实现

package com.zdxlz.lwq.service;import com.zdxlz.lwq.enity.Grade;
import com.zdxlz.lwq.mapper.GradeMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.HashMap;
import java.util.Map;@Service
public class GradeService {@AutowiredGradeMapper gradeMapper;public void insertMsg(String p_id,int score,String level){Grade grade=new Grade();grade.setP_id(p_id);grade.setScore(score);grade.setLevel(level);//插入一条新数据gradeMapper.insert(grade);}public void deleteMsgByID(int id){//根据主键删除数据gradeMapper.deleteById(id);}public void deleteMsgByMap(String key,String value){//根据条件删除数据Map<String,Object> map=new HashMap<>();map.put(key,value);gradeMapper.deleteByMap(map);}}

各层详细说明见:Spring Boot项目中的Controller、Service、Mapper和Entity层的作用与联系_mapper层的作用_琴剑飘零西复东的博客-CSDN博客,MyBatis-Plus 的 Mapper 提供一系列的 CRUD 接口,方便我们快速开发、使用,相关接口使用参阅:CRUD 接口 | MyBatis-Plus

Controller 层操作数据库

在 Controller 中的自定义方法中操作数据库,代码如下:

   @Autowiredprivate GradeService gradeService;@PostMapping("insertMsg")public String insertMsg(String p_id,int score,String level){gradeService.insertMsg(p_id,score,level);return "插入成绩:"+new Date();}@PostMapping("deleteMsgByID")public String deleteMsgByID(int id){gradeService.deleteMsgByID(id);return "删除成绩:"+new Date();}@PostMapping("deleteMsgByMap")public String deleteMsgByMap(String key,String value){gradeService.deleteMsgByMap(key,value);return "删除一组成绩:"+new Date();}

Postman 中发起网络请求,传递对应参数,即可完成数据库的相关操作

多数据源操作

dynamic-datasource-spring-boot-starter 是一个基于 Spring Boot 的快速集成多数据源的启动器,框架只做切换数据源这件核心的事情,不限制你的具体操作,切换了数据源可以做任何 CRUD,详细介绍参阅:基础必读(免费) · dynamic-datasource · 看云

在 pom 文件中增加该框架依赖,版本选择参阅(版本记录和选择建议(免费) · dynamic-datasource · 看云):

<dependency><groupId>com.baomidou</groupId><artifactId>dynamic-datasource-spring-boot-starter</artifactId><version>3.5.2</version>
</dependency>

yml 文件配置数据库信息:

spring:datasource:dynamic:primary: db1 #设置默认的数据源或者数据源组,默认值即为masterstrict: false #严格匹配数据源,默认false. true未匹配到指定数据源时抛异常,false使用默认数据源datasource:db1:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://192.168.22.82:3306/order_db_1?useUnicode=true&useSSL=falseusername: rootpassword: 123456db2:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://192.168.22.82:3306/order_db_2?useUnicode=true&useSSL=falseusername: rootpassword: 123456

定义数据库实体:

package com.zdxlz.lwq.enity;import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;import java.math.BigDecimal;
import java.util.Date;@TableName("t_order_1")
public class Order {@TableIdprivate BigDecimal order_id;@TableField("price")private int price;@TableField("user_id")private int user_id;@TableField("status")private String status;@TableField("create_date")private Date create_date;public BigDecimal getOrder_id() {return order_id;}public void setOrder_id(BigDecimal order_id) {this.order_id = order_id;}public int getPrice() {return price;}public void setPrice(int price) {this.price = price;}public int getUser_id() {return user_id;}public void setUser_id(int user_id) {this.user_id = user_id;}public String getStatus() {return status;}public void setStatus(String status) {this.status = status;}public Date getCreate_date() {return create_date;}public void setCreate_date(Date create_date) {this.create_date = create_date;}
}

创建 Mapper:

package com.zdxlz.lwq.mapper;import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.zdxlz.lwq.enity.Order;
import org.apache.ibatis.annotations.Mapper;@Mapper
public interface OrderMapper extends BaseMapper<Order> {}

创建 Service:

package com.zdxlz.lwq.service;import com.baomidou.dynamic.datasource.annotation.DS;
import com.zdxlz.lwq.enity.Order;
import com.zdxlz.lwq.mapper.OrderMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import java.math.BigDecimal;
import java.util.Date;
import java.util.Random;@Service
public class OrderService {@Autowiredprivate OrderMapper orderMapper;//插入默认数据源public void insertDB1(int price,int user_id){Order order=new Order();BigDecimal order_id=new BigDecimal(new Random().nextInt(999999));order.setOrder_id(order_id);order.setPrice(price);order.setUser_id(user_id);order.setStatus("SUCCESS");order.setCreate_date(new Date());orderMapper.insert(order);}//插入 DB2@DS("db2")public void insertDB2(int price,int user_id){Order order=new Order();BigDecimal order_id=new BigDecimal(new Random().nextInt(999999));order.setOrder_id(order_id);order.setPrice(price);order.setUser_id(user_id);order.setStatus("SUCCESS");order.setCreate_date(new Date());orderMapper.insert(order);}}

注解说明:自定义方法未添加 @DS 注解,操作默认数据源,添加 @DS 注解,将操作指定数据源,详见:基础必读(免费) · dynamic-datasource · 看云

Controller 操作数据库:

   @Autowiredprivate OrderService orderService;@PostMapping("insertDB1")public String insertDB1(int price,int user_id){orderService.insertDB1(price,user_id);return "插入默认数据库DB1:"+new Date();}@PostMapping("insertDB2")public String insertDB2(int price,int user_id){orderService.insertDB2(price,user_id);return "插入数据库DB2:"+new Date();}

测试验证:

使用 Postman 分别发起请求 insertDB1、insertDB2,请求完成后使用 MySQL 可视化工具,分别查看两个数据库的插入情况

开源项目地址:GitHub - liuweiqiang2016/SpringBootDemo: SpringBoot 框架入门学习

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/221707.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

QTextEdit多行富文本框控件

​锋哥原创的PyQt6视频教程&#xff1a; 2024版 PyQt6 Python桌面开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili2024版 PyQt6 Python桌面开发 视频教程(无废话版) 玩命更新中~共计21条视频&#xff0c;包括&#xff1a;2024版 PyQt6 Python桌面开发 视频教程(无废话…

2023年11月27日历史上的今天大事件早读

1852年11月27日 计算机程序创始人阿达-洛芙莱斯去世 1893年11月27日 抗日爱国将领续范亭诞辰 1895年11月27日 《茶花女》作者、法国著名作家小仲马逝世 1899年11月27日 董其武将军诞辰 1902年11月27日 《新小说》创刊 1907年11月27日 割让刚果给比利时的条约签订 1925年1…

Java代码生成器,一键在线生成,支持自定义模板

【Java代码生成神器】自动化生成Java实体类、代码、增删改查功能&#xff01;点击访问 推荐一个自己每天都在用的Java代码生成器&#xff01;这个网站支持在线生成Java代码&#xff0c;包含完整的Controller\Service\Entity\Dao代码&#xff0c;完整的增删改查功能&#xff01…

虾皮买手号怎么弄的

想要拥有虾皮买手号&#xff0c;可以使用shopee买家通系统进行自动化注册&#xff0c;这款软件目前支持菲律宾、泰国、马来西亚、越南、巴西、印度尼西亚等国家使用。 软件注册流程简单方便&#xff0c;首先我们需要先准备好手机号&#xff0c;因为现在注册虾皮买家号基本上都是…

学习.NET验证模块FluentValidation的基本用法(续3:ASP.NET Core中的调用方式)

FluentValidation模块支持在ASP.NET Core项目中进行手工或自动验证&#xff0c;主要验证方式包括以下三种&#xff1a;   1&#xff09;手工注册验证类&#xff0c;并在控制器或其它模块中调用验证&#xff1b;   2&#xff09;基于ASP.NET验证管道&#xff08;validation …

COMP2121 Discrete Mathematics

COMP2121 Discrete Mathematics 需要可WeChat: zh6-86

Java 注解在 Android 中的使用场景

Java 元注解有 5 种&#xff0c;常用的是 Target 和 Retention 两个。 其中 Retention 表示保留级别&#xff0c;有三种&#xff1a; RetentionPolicy.SOURCE - 标记的注解仅保留在源码级别中&#xff0c;并被编译器忽略RetentionPolicy.CLASS - 标记的注解在编译时由编译器保…

【C++高阶(五)】哈希思想--哈希表哈希桶

&#x1f493;博主CSDN主页:杭电码农-NEO&#x1f493;   ⏩专栏分类:C从入门到精通⏪   &#x1f69a;代码仓库:NEO的学习日记&#x1f69a;   &#x1f339;关注我&#x1faf5;带你学习C   &#x1f51d;&#x1f51d; 哈希结构 1. 前言2. unordered系列容器3. 哈希概…

EM32DX-C1【分布式io】

1设备类型&#xff1a; 电压&#xff1a;DC24V 输入16点 输出16点雷赛 EM32DX-C1 模块是一款基于 ASIC 技术的高性能、高可靠性的 CANopen 总线数字 量输入输出扩展模块&#xff0c;具有 16 路通用输入接口和 16 路通用输出接口。输入输出接口均采用光 电隔离和…

手机爬虫用Fiddler详细教程

如果你正在进行手机爬虫的工作&#xff0c;那么一款强大而又实用的网络调试工具Fiddler将会是你的好帮手。今天&#xff0c;我将和大家分享一份详细的Fiddler教程&#xff0c;教你如何使用它来轻松捕获和分析手机App的网络请求。让我们一起来探索Fiddler的功能和操作&#xff0…

visual Studio MFC 绘制单一颜色三角形、渐变颜色边框三角形、渐变填充三角形、边框渐变的正方形与填充渐变的正方形实例

MFC 绘制三角形 本文使用visual Studio MFC 平台实现绘制单一颜色三角形、渐变颜色边框三角形、渐变填充三角形、边框渐变的正方形与填充渐变的正方形. 关于基础工程的创建请参考Visual Studio 使用MFC 单文档工程绘制单一颜色直线和绘制渐变颜色的直线 文章目录 MFC 绘制三角形…

IO和NIO的区别 BIO,NIO,AIO 有什么区别? Files的常用方法都有哪些?

文章目录 IO和NIO的区别BIO,NIO,AIO 有什么区别?Files的常用方法都有哪些&#xff1f; 今天来对java中的io, nio, bio, aio进行了解&#xff0c;有何区别。 IO和NIO的区别 NIO与IO区别 IO是面向流的&#xff0c;NIO是面向缓冲区的Java IO面向流意味着每次从流中读一个或多个字…