SpringBoot整合Mybatis之Mapper接口和映射文件

news2025/1/21 8:55:31

一、什么是MyBatis

MyBatis中文网https://mybatis.net.cn/

MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

二、MyBatisPlus与MyBatis的关系

MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。也就是说Mybatis拥有的功能,MybatisPlus全都拥有。所以SpringBoot在集合MyBatis-Plus 时,同时也集合了MyBatis。

三、maven依赖

1. SpringBoot整合mybatis的依赖

<dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.2.2</version>
 </dependency>

2. SpringBoot整合mybatisPlus的依赖

<!--MybatisPlus中包含了mybatis -->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.4.2</version>
</dependency>

四、配置,application.yml (MybatisPlus的配置)

spring:
  datasource:
    druid:
      driver-class-name: com.mysql.cj.jdbc.Driver
      url: jdbc:mysql://localhost:3306/reggie?serverTimezone=UTC
      username: root
      password: yqqlm@gs1cl

mybatis-plus:
  configuration:
    map-underscore-to-camel-case: true
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  mapper-locations: classpath*:/mapper/**/*.xml

五、创建Mapper接口

Mapper接口中的方法用来操作数据库,调用接口中的方法时,会根据方法名匹配到sql语句。

六、映射文件

1、映射文件的命名规则

表所对应的实体类的类名+Mapper.xml

例如:表dish,映射的实体类为Dish,所对应的映射文件为DishMapper.xml

因此一个映射文件对应一个实体类,对应一张表的操作。

Mybatis映射文件用于编写SQL,访问以及操作表中的数据

Mybatis映射文件默认存放的位置是classpath*:/mapper/**/*.xml

2. Mybatis中可以面向接口操作数据,要保证两个一致

  • mapper接口的全类名和映射文件的命名空间(namespace)保持一致
  • mapper接口中方法的方法名和映射文件中编写SQL的标签的id属性保持一致
@Mapper
public interface DishMapper extends BaseMapper<Dish> {
    //Mybatis面向接口编程的两个一致
    Dish getDishByName(@Param("name") String name);
}

3. 映射文件的标准格式

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.athorse.mapper.DishMapper">
    <select id="getDishByName" resultType="com.athorse.entities.Dish">
        select * from dish where name = #{name}
    </select>
</mapper>

七、详解映射文件

1. select标签

<!--查询共嗯那个的标签必须设置resultType或者resaultMap
    resultType:设置默认的映射关系,表字段名与实体类属性名一一对应
    resaultMap:设置自定义的映射关系,表字段名与实体类属性名不一样表中id与实体类属性dishId,就需要自定义映射
 -->
<select id="getDishByName" resultType="com.athorse.entities.Dish">
    select * from dish where name = #{name}
 </select>

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

消息中间件执行原理

1 关于消息中间件 1.1 什么是消息中间件&#xff1f; 消息中间件是指在分布式系统中完成消息的发送和接收的基础软件。 消息中间件也可以称消息队列&#xff08;Message Queue / MQ&#xff09;&#xff0c;用高效可靠的消息传递机制进行与平台无关的数据交流&#xff0c;并基…

区块链技术应用展望

区块链作为一个"去中心化"的分布式账本数据库&#xff0c;能够让数据的产生、运行和应用更加公开与透明。区块链被认为是互联网之后又一大创新之举&#xff0c;是第二个互联网时代——价值互联网时代的来临&#xff0c;区块链将从基础设施层面为各行各业带来巨大的变…

力扣(LeetCode)353. 贪吃蛇(2022.12.20)

请你设计一个 贪吃蛇游戏&#xff0c;该游戏将会在一个 屏幕尺寸 宽度 x 高度 的屏幕上运行。如果你不熟悉这个游戏&#xff0c;可以 点击这里 在线试玩。 起初时&#xff0c;蛇在左上角的 (0, 0) 位置&#xff0c;身体长度为 1 个单位。 你将会被给出一个数组形式的食物位置…

C++中二叉树的递归遍历方法

在《C中二叉树的非递归遍历方法2-1》中提到&#xff0c;二叉树的遍历分为前序遍历、中序遍历、后序遍历和层序遍历四种。要遍历的二叉树如图1所示。 图1 二叉树结构 创建该二叉树的代码请参见《C中二叉树的非递归遍历方法2-1》。 1 前序遍历的递归实现 前序遍历的输出顺序是…

VC2010 的控制台程序中使用 EasyX

以下是在 VC2010 的控制台应用程序中使用 EasyX 的具体步骤&#xff1a; 1. 启动 VC2010&#xff0c;点击菜单 File -> New -> Project...&#xff0c;打开 New Project 对话框&#xff1a; 2. 选择 “Win32 Console Application” 类型的项目&#xff0c;并选择项目所在…

「驱动知识」Linux下RTC时间的读写分析

Linux下RTC时间的读写分析​ 1.1.1 系统时间与RTC时间​ Linux系统下包含两个时间&#xff1a;系统时间和RTC时间。​ 系统时间&#xff1a;是由主芯片的定时器进行维护的时间&#xff0c;一般情况下都会选择芯片上最高精度的定时器作为系统时间的定时基准&#xff0c;以避免…

【我不熟悉的javascript】map和weakmap的区别

map 保存键值对&#xff0c;并且能够记住键的原始插入顺序&#xff0c;任何值(对象或者基本类型)都可以作为一个键或一个值 基本方法有 get, set, has, delete, clear长度 .size迭代 keys, values, extries, forEach可以使用for ...of 迭代任何值(对象或者基本类型)都可以作为…

如何在头条做营销:2022今日头条营销价值洞察报告.pdf(附下载链接)

省时查报告-专业、及时、全面的行研报告库省时查方案-专业、及时、全面的营销策划方案库【免费下载】2022年11月份热门报告盘点《底层逻辑》高清配图华为2021数字化转型&#xff1a;从战略到执行.pdf华为项目管理金种子培训教材.pdf清华大学256页PPT元宇宙研究报告.pdf&#xf…

nn.AdaptiveAvgPool2d和nn.AvgPool2d的区别

nn.AdaptiveAvgPool2d 功能&#xff1a;该函数与二维平均池化运算类似&#xff0c;区别主要体现在自适应上&#xff0c;对于任何输入大小&#xff0c;输出大小均为指定的HW大小。 nn.AdaptiveAvgPool2d(output_size)output_size&#xff1a;指定的输出大小&#xff0c;可以是…

echarts-for-weixin只显示折线图,其他不显示解决办法

小程序使用echarts-for-weixin展示图表&#xff0c;结果只展示折线图&#xff0c;其他的统统不显示&#xff0c;百度大法一下午终于知道可能是echarts包内只有折线图。 下载好替换搞定&#xff01;

【Vue 快速入门系列】3分钟掌握Vue中插槽的使用与理解

文章目录前言一、常规实现方式二、匿名插槽三、具名插槽四、作用域插槽前言 插槽作用&#xff1a;让父组件可以向子组件指定位置插入html结构&#xff0c;也是一种组件间通信的方式&#xff0c;适用于 父组件 > 子组件 。 插槽分类&#xff1a;默认插槽、具名插槽、作用域插…

docker部署solr+zk集群

在三台服务器上搭建solr集群&#xff0c;具体架构如下所示&#xff1a; 192.168.184.127 solr1/zk1 192.168.184.128 solr2/zk2 192.168.184.129 solr3/zk3 1.安装docker 三台服务器上都执行以下命令 # setenforce 0 # systemctl stop firewall…

代码随想录Day56|583.两个字符串的删除操作 、72.编辑距离、编辑距离总结篇

文章目录583.两个字符串的删除操作72.编辑距离编辑距离总结篇583.两个字符串的删除操作 文章讲解&#xff1a;代码随想录 (programmercarl.com) 题目链接&#xff1a;583. 两个字符串的删除操作 - 力扣&#xff08;LeetCode&#xff09; 题目&#xff1a; 给定两个单词 wor…

Flume EmbeddedAgent

flume flume 二次开发&#xff0c;对EmbeddedAgent的简易改造&#xff0c;动态控制agent&#xff0c;实现启动、关闭等功能。 模块结构如下所示&#xff1a; flume-parent github地址 1、用途 1.1、本地调试 对flume不是特别熟悉的开发者&#xff0c;都没有办法一次开发完…

消息队列mq

1. 为什么使用消息队列&#xff1f; 其实就是问问你消息队列都有哪些使用场景&#xff0c;然后你项目里具体是什么场景&#xff0c;说说你在这个场景里用消息队列是什么&#xff1f; 解耦、异步、削峰 2. 消息队列优缺点 2.1.优点 优点上面已经说了&#xff0c;就是在特殊…

并查集的原理及实现

Ⅰ. 并查集原理 在一些应用问题中&#xff0c;需要将 n 个不同的元素划分成一些不相交的集合。开始时&#xff0c;每个元素自成一个单元素集合&#xff0c;然后按一定的规律将归于同一组元素的集合合并。在此过程中要反复用到查询某一个元素归属于那个集合的运算。适合于描述这…

前端基础_线型Line styles

线型Line styles 线型包括如下属性。 lineWidth value lineCap type lineJoin type miterLimit value 通过这些属性来设置线的样式。下面将结合实例来讲解一下各属性的应用及应用后的效果。 lineWidth属性 该属性设置当前绘线的粗细&#xff0c;属性值必须…

ArcGIS编辑绘制图斑又慢又难?这些高效的处理技巧你值得拥有!

GIS画图是不是画得很慢! 图斑修改是不是无从下手! 图纸矢量化是不是琐碎繁杂、工作量大! 其实,强大的ArcGIS有很多高效的图斑编辑技巧,掌握这些技巧,无论是绘制图斑、还是修改图斑,还是图纸矢量化,绝对让你事半功倍! NO.1—自动完成面 当你要绘制一个图斑的相邻图…

华为云桌面,企业云上办公为何都偏好它?

在众多云上办公产品中&#xff0c;华为云桌面基于华为云的三十年投入的技术强、资源多、创新快和更可靠的优势&#xff0c;在众多云上办公产品中脱颖而出&#xff0c;成为众多企业数字化转型道路上不二选择&#xff0c;类似于三一重工、中泰模具、小飞侠等企业都选择了华为云桌…

非递归前序、中序遍历代码推演出后序遍历代码(极其透彻)

一、前言 众所周知&#xff0c;二叉树的遍历方式有三种&#xff1a;前序遍历、中序遍历和后序遍历。 &#x1f34c; 前序遍历&#xff1a;首先访问根节点&#xff0c;然后递归遍历左子树&#xff0c;最后递归遍历右子树。 &#x1f34c; 中序遍历&#xff1a;首先递归遍历左…