Mybatis 到 MyBatisPlus

Mybatis 到 MyBatisPlus

Mybatis

MyBatis(官网:https://mybatis.org/mybatis-3/zh/index.html )是一款优秀的 持久层 (ORM)框架,用于简化JDBC的开发。是 Apache的一个开源项目iBatis,2010年这个项目由apache迁移到了google code,并且改名为MyBatis 。2013年11月迁移到Github。

MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。

MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

    持久层:指的是就是数据访问层(dao),是用来操作数据库的。

1. 依赖和配置

引入 mybatis 依赖和数据库连接依赖
<dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.2.2</version>
</dependency><dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId><scope>runtime</scope></dependency>

数据源信息和mapper映射扫描配置:

spring:datasource:url: jdbc:mysql://localhost:3306/cloud_user?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTCusername: rootpassword: 123456driver-class-name: com.mysql.cj.jdbc.Drivermybatis:mapper-locations: classpath:mapper/*.xml

Spring MapperScan自动扫描配置
一般在启动类上新增 MapperScan 注解即可

@MapperScan("com.pjh.apigf.mapper")

本案例使用 mybatis-spring-boot-starter 自动装配依赖,因此 mybatis 会自动读取spring.datasource 下面的数据源配置信息;并会自动扫描 @mapper 注解的类加入Ioc容器中进行管理。

注意:如果使用 spring + mybatis 依赖,则需要在 mybatis-config.xml 中指定 数据源信息,mapperScan 目录等,否则会报错。

2. 基本使用

使用时需要创建对应的实体类,对应的 mapper.java 持久层;

2.1 Mapper映射实现

要求 Mapper.xml 与Mapper.java 在相同目录结构下:
在这里插入图片描述
在 Mapper.java 中创建需要的数据操作方法

User getUserById(@Param("userId") String userId) ;

相同的 Mapper.xml 中需要有对应的方法
在这里插入图片描述
常用的标签:

select: 用于查询操作,从数据库中检索数据。
id: 唯一标识符,用于匹配接口方法。
resultType: 查询结果的Java类型,可以是具体类名或别名。
resultMap: 当查询结果需要复杂的映射关系时使用,引用之前定义的<resultMap>。
parameterType: 传入参数的类型,通常是Java Bean类型或基本类型。insert: 用于插入操作,向数据库插入数据。
id, parameterType, useGeneratedKeys, keyProperty: 类似于<select>,其中useGeneratedKeys和keyProperty用于处理自动生成的主键。update: 用于更新操作,更新数据库中的数据。
id, parameterType: 同上。delete: 用于删除操作,从数据库中删除数据。
id, parameterType: 同上。动态SQL标签:
<if>: 根据条件判断是否包含某段SQL<choose>, <when>, <otherwise>: 类似于Javaswitch-case语句。
<where>: 动态生成WHERE子句,自动处理第一个条件前的ANDOR<set>: 用于动态生成UPDATE语句的SET子句。
<foreach>: 遍历集合,常用于IN语句中。sql: 定义可重用的SQL片段,提高代码复用性。
id: 片段的唯一标识。resultMap: 复杂结果集的映射,定义列名到JavaBean属性的映射关系。
id: resultMap的唯一标识。
type: 映射的目标Java类型。
<id><result>: 分别定义主键映射和普通属性映射
2.2 注解方式实现
  • @Select用于标记查询语句。该注解可以在接口方法上使用,也可以在XML文件中使用。使用@Select注解时,需要在注解中指定SQL语句
  • @Insert用于标记插入语句。该注解可以在接口方法上使用,也可以在XML文件中使用。使用@Insert注解时,需要在注解中指定SQL语句。
  • @Update用于标记更新语句。该注解可以在接口方法上使用,也可以在XML文件中使用。使用@Update注解时,需要在注解中指定SQL语句。
  • @Delete用于标记删除语句。该注解可以在接口方法上使用,也可以在XML文件中使用。使用@Delete注解时,需要在注解中指定SQL语句。
  • @Results用于标记结果集映射,该注解可以用于接口方法或XML文件中,通常与@Select注解一起使用。使用@Results注解时,需要指定Result映射规则。
@Select("SELECT * FROM users WHERE id = #{id}")
@Results(id = "userResultMap", value = {@Result(property = "id", column = "id"),@Result(property = "name", column = "name"),@Result(property = "age", column = "age")
})
User getUserById(@Param("id") Long id);
  • @Result用于标记单个属性与结果集中的列之间的映射关系。该注解可以用于接口方法或XML文件中,通常与@Results注解一起使用。使用@Result注解时,需要指定映射规则。
  • @ResultMap用于标记结果集映射规则。该注解可以用于接口方法或XML文件中,通常与@Select注解一起使用。使用@ResultMap注解时,需要指定映射规则。
@Select("SELECT * FROM users WHERE id = #{id}")
@ResultMap("userResultMap")
User getUserById(@Param("id") Long id);
  • @Options用于指定一些可选的配置项。该注解可以用于接口方法或XML文件中,通常与@Insert、@Update、@Delete等注解一起使用。使用@Options注解时,可以指定一些可选的配置项。
    useGeneratedKeys :自增主键并返回,keyProperty 实体对应的元素
@Insert("INSERT INTO users(name, age) VALUES(#{name}, #{age})")
@Options(useGeneratedKeys = true, keyProperty = "id")
int insertUser(User user);
  • @SelectKey用于在执行INSERT语句后获取自动生成的主键值。该注解可以用于接口方法或XML文件中,通常与@Insert注解一起使用。使用@SelectKey注解时,需要指定生成主键的SQL语句和将主键值赋给Java对象的哪个属性。
@Insert("INSERT INTO users(name, age) VALUES(#{name}, #{age})")
@SelectKey(statement = "SELECT LAST_INSERT_ID()", keyProperty = "id", before = false, resultType = Long.class)
int insertUser(User user);
  • @Param用于为SQL语句中的参数指定参数名称。该注解可以用于接口方法或XML文件中,通常与@Select、@Insert、@Update、@Delete等注解一起使用。使用@Param注解时,需要指定参数名称。
@Select("SELECT * FROM users WHERE name = #{name} AND age = #{age}")
List<User> getUsersByNameAndAge(@Param("name") String name, @Param("age") Integer age);
  • @One用于在一对一关联查询中指定查询结果的映射方式。该注解可以用于XML文件中,通常与和标签一起使用。使用@One注解时,需要指定查询结果映射的Java对象类型和查询结果映射的属性。
<resultMap id="userResultMap" type="User"><id column="id" property="id"/><result column="name" property="name"/><result column="age" property="age"/><association property="department" resultMap="departmentResultMap"/>
</resultMap><resultMap id="departmentResultMap" type="Department"><id column="id" property="id"/><result column="name" property="name"/><result column="description" property="description"/><one property="manager" resultMap="userResultMap"/>
</resultMap>

上述代码中,@One注解用于指定查询结果的映射方式,这里使用了嵌套的标签实现了一对一关联查询。在departmentResultMap中,使用@One注解指定了查询结果映射的Java对象类型为User,查询结果映射的属性为manager,resultMap参数指定了查询结果映射的结果集映射规则为userResultMap。

  • @Many用于在一对多关联查询中指定查询结果的映射方式。该注解可以用于XML文件中,通常与和标签一起使用。使用@Many注解时,需要指定查询结果映射的Java对象类型和查询结果映射的属性。
<resultMap id="departmentResultMap" type="Department">
<id column="id" property="id"/>
<result column="name" property="name"/>
<result column="description" property="description"/>
<collection property="members" ofType="User" resultMap="userResultMap"/>
</resultMap><resultMap id="userResultMap" type="User"><id column="id" property="id"/><result column="name" property="name"/><result column="age" property="age"/>
</resultMap>
  • @ResultType用于指定查询结果的类型。该注解可以用于接口方法或XML文件中,通常与@Select、@Insert、@Update、@Delete等注解一起使用。使用@ResultType注解时,需要指定查询结果的类型。
@Select("SELECT name, age FROM users WHERE id = #{id}")
@ResultType(User.class)
User getUserById(Long id);
  • @TypeDiscriminator用于在自动映射时指定不同子类型的映射方式。该注解可以用于XML文件中,通常与和标签一起使用。使用@TypeDiscriminator注解时,需要指定类型列的名称和不同子类型的映射方式。
<resultMap id="vehicleResultMap" type="Vehicle">
<id column="id" property="id"/>
<result column="name" property="name"/>
<result column="type" property="type"/><discriminator javaType="String" column="type"><case value="car" resultMap="carResultMap"/><case value="truck" resultMap="truckResultMap"/><case value="bus" resultMap="busResultMap"/></discriminator>
</resultMap>
<resultMap id="carResultMap" type="Car"><result column="engine" property="engine"/><result column="seats" property="seats"/>
</resultMap>
<resultMap id="truckResultMap" type="Truck"><result column="load" property="load"/>
</resultMap>
<resultMap id="busResultMap" type="Bus"><result column="capacity" property="capacity"/>
</resultMap>

上述代码中,@TypeDiscriminator注解用于指定不同子类型的映射方式。在vehicleResultMap中,使用@TypeDiscriminator注解指定了类型列的名称为type,javaType参数指定了类型列的Java类型为String,标签中的value属性分别对应不同的子类型(car、truck、bus),resultMap属性用于指定不同子类型的结果集映射规则。

MyBatisPlus

CRUD 操作:MyBatisPlus 提供了丰富的 CRUD 方法(如 insert, update, delete, select),开发者无需编写 SQL 语句,仅通过方法名即可实现基本的数据库操作。而在 MyBatis 中,你需要为每一个 CRUD 操作编写 SQL 语句。
条件构造器:MBP 提供了强大的条件构造器,可以灵活构建复杂的 WHERE 条件,这相比 MyBatis 手动拼接 SQL 更加方便且安全。
分页支持:MBP 内置了分页插件,只需简单配置即可实现物理分页,而 MyBatis 需要手动编写分页逻辑或者集成第三方分页插件。
性能优化:比如自动填充(如创建时间、更新时间)、乐观锁等功能,MBP 提供了开箱即用的解决方案,减少了开发者在这些常规需求上的重复工作。
注解驱动:MBP 强化了注解的使用,很多功能可以通过简单的注解配置实现,降低了 XML 配置文件的依赖,使得项目结构更加清晰。

踩坑

分清 spring 依赖,和 boot 自动装配依赖。使用原生的 mybatis 依赖需要配置mybatis-config.xml 配置文件,大致如下,关键内容为 dataSource、SqlSessionFactoryBean、MapperScannerConfigurer;而使用 boot 自动装配依赖时会将以上配置和bean进行自动装配。

<?xml version="1.0" encoding="UTF-8" ?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd"
><context:component-scan base-package="com.pjh.apigf.mapper"></context:component-scan><!-- 加载jdbc.properties配置文件 --><context:property-placeholder location="classpath:jdbc.properties"/><!-- 配置 MyBatis 数据源 --><bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"><property name="driverClassName" value="${database.driver}" /><property name="url" value="${database.url}" /><property name="username" value="${database.username}" /><property name="password" value="${database.password}" /></bean><!-- 配置 mybatis Session --><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><property name="dataSource" ref="dataSource" /><!--<property name="configLocation" value="classpath:mybatis-config.xml"></property>--><property name="mapperLocations" value="classpath:com/pjh/apigf/mapper/*.xml" /></bean><!-- 扫描Mapper接口(Spring会使用AOP为其实现具体方法) --><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><property name="basePackage" value="top.yiqifu.study.p061_mybatis" /></bean></beans>

mybatis-spring-boot-starter 和普通的 mybatis 依赖有以下几个主要区别:

集成便利性:
mybatis-spring-boot-starter 是专为 Spring Boot 应用设计的 Starter,它提供了自动配置的功能,使得在 Spring Boot 应用中集成 MyBatis 变得更加简便。你只需要在 pom.xml 中添加这个 Starter 依赖,无需手动编写大量的配置代码,Spring Boot 会自动配置好 MyBatis 的关键组件,比如 SqlSessionFactory 和 SqlSessionTemplate。
普通的 mybatis 依赖则是 MyBatis 的核心库,不包含任何 Spring 特定的集成代码。在非 Spring Boot 项目或者传统的 Spring 项目中使用时,你需要手动配置数据源、SqlSessionFactory、事务管理器等组件,并且可能需要额外的 mybatis-spring 依赖来桥接 MyBatis 和 Spring。

自动配置:
mybatis-spring-boot-starter 内部集成了自动配置逻辑,可以根据应用的环境和配置文件(如 application.properties 或 application.yml)自动设置 MyBatis 的配置项,比如映射文件的位置、类型别名、数据源等。
使用普通的 mybatis 依赖时,这些配置都需要手动在 Spring 配置类中完成。

依赖管理:
mybatis-spring-boot-starter 作为 Spring Boot 的 Starter,它内部已经管理了必要的依赖关系,例如它会自动引入 mybatis, mybatis-spring 以及可能的其他相关依赖,确保版本兼容性。这减少了 Maven 或 Gradle 依赖冲突的可能性。
使用普通 mybatis 依赖时,你需要自己管理所有相关依赖及其版本兼容性。

约定优于配置:
Spring Boot 的理念是“约定优于配置”,mybatis-spring-boot-starter 遵循这一原则,很多配置都有默认值,开发者只需关注需要改变的部分。而传统方式使用 MyBatis 则需要显式地配置每一部分。

综上所述,mybatis-spring-boot-starter 提供了一种快速、简化的方式来在 Spring Boot 应用中集成 MyBatis,减少了手动配置的工作量,并且通过自动配置和依赖管理提高了开发效率。而普通的 MyBatis 依赖则提供了更多的灵活性,但需要开发者自行处理更多的配置细节。

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

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

相关文章

【图像处理实战】去除光照不均(Python)

这篇文章主要是对参考文章里面实现一种小拓展&#xff1a; 可处理彩色图片&#xff08;通过对 HSV 的 V 通道进行处理&#xff09;本来想将嵌套循环改成矩阵运算的&#xff0c;但是太麻烦了&#xff0c;而且代码也不好理解&#xff0c;所以放弃了。 代码 import cv2 import …

虚拟化 之八 详解构造带有 jailhouse 的 openEuler 发行版(ARM 飞腾派)

基本环境 嵌入式平台下,由于资源的限制,通常不具备通用性的 Linux 发行版,各大主流厂商都会提供自己的 Linux 发行版。这个发行版通常是基于某个 Linux 发行版构建系统来构建的,而不是全部手动构建,目前主流的 Linux 发行版构建系统是 Linux 基金会开发的 Yocto 构建系统。…

用一个暑假|用AlGC-stable diffusion 辅助服装设计及展示,让你在同龄人中脱颖而出!

大家好&#xff0c;我是设计师阿威 Stable Diffusion是一款开源AI绘画工具&#xff0c; 用户输入语言指令&#xff0c;即可自动生成各种风格的绘画图片 Stable Diffusion功能强大&#xff0c;生态完整、使用方便。支持大部分视觉模型上传&#xff0c;且可自己定制模型&#x…

什么是大模型?一文读懂大模型的基本概念

大模型是指具有大规模参数和复杂计算结构的机器学习模型。本文从大模型的基本概念出发&#xff0c;对大模型领域容易混淆的相关概念进行区分&#xff0c;并就大模型的发展历程、特点和分类、泛化与微调进行了详细解读&#xff0c;供大家在了解大模型基本知识的过程中起到一定参…

win7 的 vmware tools 安装失败

没有安装vmware tools的系统屏幕显示异常。桌面是比较小的图像&#xff0c;四周是黑边在 vmware 软件里 方法1&#xff0c;下补丁 https://www.catalog.update.microsoft.com/Search.aspx?qkb4474419 方法2&#xff0c;使用老版vm tools http://softwareupdate.vmware.com/c…

【ARM】MDK工程切换高版本的编译器后出现error A1137E报错

【更多软件使用问题请点击亿道电子官方网站】 1、 文档目标 解决工程从Compiler 5切换到Compiler 6进行编译时出现一些非语法问题上的报错。 2、 问题场景 对于一些使用Compiler 5进行编译的工程&#xff0c;要切换到Compiler 6进行编译的时候&#xff0c;原本无任何报错警告…

各大广告商竞相厮杀下,诞生了一个偏门的副业方式

前段时间&#xff0c;想买摩托车&#xff0c;但是媳妇不让买&#xff0c;所以我打算偷偷买&#xff0c;然后萌生了去摆摊赚钱的想法&#xff0c;但是还没有实施就在网上接触到了“某赚”APP&#xff0c;于是一发不可收拾&#xff0c;用我的话来说&#xff0c;我做的不是副业&am…

佑驾创新A股夭折再冲港股:三年亏损超5亿,商业化盈利难题何解

《港湾商业观察》廖紫雯 日前&#xff0c;深圳佑驾创新科技股份有限公司&#xff08;以下简称&#xff1a;佑驾创新&#xff09;递表港交所&#xff0c;保荐机构为中信证券、中金公司。佑驾创新曾于2023年8月启动A股上市辅导&#xff0c;但2024年5月公司终止了与辅导机构的上市…

【ai】trition:tritonclient yolov4:部署ubuntu18.04

X:\05_trition_yolov4_clients\01-python server代码在115上,client本想在windows上, 【ai】trition:tritonclient.utils.shared_memory 仅支持linux 看起来要分离。 client代码远程部署在ubuntu18.04上 ubuntu18.04 创建yolov4-trition python=3.7 环境 (base) zhangbin@ub…

基于matlab的图像灰度化与图像反白

1原理 2.1 图像灰度化原理 图像灰度化是将彩色图像转换为灰度图像的过程&#xff0c;使得每个像素点仅包含一个灰度值&#xff0c;从而简化了图像的复杂度。灰度化原理主要可以分为以下几种方法&#xff1a; 亮度平均法 原理&#xff1a;将图像中每个像素的RGB值的平均值作为…

[深度学习] 生成对抗网络GAN

生成对抗网络&#xff08;Generative Adversarial Networks&#xff0c;GANs&#xff09;是一种由 Ian Goodfellow 等人在2014年提出的深度学习模型Generative Adversarial Networks。GANs的基本思想是通过两个神经网络&#xff08;生成器和判别器&#xff09;的对抗过程&#…

VMware vCenter Server 8.0U3 发布下载 - 集中式管理 vSphere 环境

VMware vCenter Server 8.0U3 发布下载 - 集中式管理 vSphere 环境 Server Management Software | vCenter 请访问原文链接&#xff1a;https://sysin.org/blog/vmware-vcenter-8-u3/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主页&#xff1a;sys…

如何解决ssh远程连接自动断开的问题

文章目录 1. 问题描述2. 配置SSH设置2.1 调整服务器端的设置2.2 调整客户端的设置 3. 调整用户断开时长 1. 问题描述 SSH 远程连接断开是一个常见的问题&#xff0c;尤其是在网络不稳定或长时间没有活动时。文本介绍一些常见的方法和技巧来保持 SSH 连接稳定和避免断开。 2. …

基于Python/MNE处理fnirs数据

功能性近红外光谱技术在脑科学领域被广泛应用&#xff0c;市面上也已经有了许多基于MATLAB的优秀工具包及相关教程&#xff0c;如&#xff1a;homer、nirs_spm等。而本次教程将基于Python的MNE库对fNIRS数据进行处理。 本次教程基于&#xff1a;https://mne.tools/stable/auto_…

自动驾驶系统功能安全解决方案解析

电信、公用事业、运输和国防等关键基础设施服务需要定位、导航和授时&#xff08;PNT&#xff09;技术来运行。但是&#xff0c;广泛采用定位系统&#xff08;GPS&#xff09;作为PNT信息的主要会引入漏洞。 在为关键基础设施制定PNT解决方案时&#xff0c;运营商必须做出两个…

运维入门技术——监控的三个维度(非常详细)零基础收藏这一篇就够了_监控维度怎么区分

一个好的监控系统最后要做到的形态:实现Metrics、Tracing、Logging的融合。监控的三个维度也就是Metrics、Tracing、Logging。 Metrics Metrics也就是我们常说的指标。 首先它的典型特征就是可聚合(aggregatable).什么是可聚合的呢,简单讲可聚合就是一种基本单位可以在一种维…

uniapp标题水平对齐微信小程序胶囊按钮及适配

uniapp标题水平对齐微信小程序胶囊按钮及适配 状态栏高度胶囊按钮的信息计算顶部边距模板样式 标签加样式加动态计算实现效果 状态栏高度 获取系统信息里的状态栏高度 const statusBarHeight uni.getSystemInfoSync().statusBarHeight;//系统信息里的状态栏高度胶囊按钮的…

钢筋计在工程项目中的关键应用与优势

在长期工程项目中&#xff0c;如大型桥梁、高层建筑或深基坑工程中&#xff0c;钢筋是承载结构的重要组成部分。为确保工程质量和安全&#xff0c;监测与管理钢筋的状态至关重要。钢筋计作为一种先进的监测工具&#xff0c;在长期工程项目中发挥着不可替代的作用。 1. 钢筋计的…

Spring Boot 学习第八天:AOP代理机制对性能的影响

1 概述 在讨论动态代理机制时&#xff0c;一个不可避免的话题是性能。无论采用JDK动态代理还是CGLIB动态代理&#xff0c;本质上都是在原有目标对象上进行了封装和转换&#xff0c;这个过程需要消耗资源和性能。而JDK和CGLIB动态代理的内部实现过程本身也存在很大差异。下面将讨…

VMware Workstation搭建Windows Server2019主备AD域控详细操作步骤

版本 虚拟机版本 VMware Workstation 16 Prp 16.2.5 build-20904516 服务器系统版本 具体操作 安装第一台虚拟机服务器 首先先创建一台Windows Server2019虚拟机&#xff0c;可以参考VMware Workstation安装Windows Server2019系统详细操作步骤-CSDN博客 克隆第一台虚拟机…