MyBatis--Mapper代理开发和MyBatisX插件使用

2023-11-05 14:51

本文主要是介绍MyBatis--Mapper代理开发和MyBatisX插件使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 一、Mapper代理开发
    •     1、定义mapper接口
    •     2、设置mapper接口全限定名
    •     3、定义接口里面的方法
    •     4、修改sql映射文件为包扫描方式
    •     5、编码
    • 二、mybatisx插件的安装
    •     1、下载
    •     2、使用

一、Mapper代理开发

    1、定义mapper接口

定义与sql映射同名的mapper接口,将映射文件和mapper接口放在同一个包目录下。
1.配置sql映射文件
在resources下新建一个xml文件,将以下内容复制进去。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="org.mybatis.example.BlogMapper"><select id="selectBlog" resultType="Blog">select * from Blog where id = #{id}</select>
</mapper>

修改id,类型,以及你的sql语句
在这里插入图片描述
2.定义mapper接口,这个接口方法名一定要和你的映射文件名对应,后续执行sql语句才能找到。
我这里mapper映射文件名称是UserMapper.xml,所以我需要定义一个叫UserMapper的接口。
在这里插入图片描述
3.将UserMapper借口和UserMapper.xml放置在同一个包目录下。
现在我的UserMapper借口在com.mybatis.mapper包下,而UserMapper.xml映射文件在resources包下。显然两个文件不在一个包目录下。
在这里插入图片描述
你可以把两个文件拖到一个包下,这是一种方法。只是这种方法复用性不好,对后期代码维护不友好。当然有其他办法,就是在resources目录下建一个和UserMapper相同目录的包,比如我这里就是com/mybatis/mapper,注意要用斜线,不能用点,但是建好包之后他会自动转化成为点,不用担心。然后把UserMapper.xml拖进去就行了。
在这里插入图片描述
那怎么证明他两在同一个包目录下呢?只需要编译后,在对应包目录下就可以看见两个在同一个目录下。
在这里插入图片描述
到现在定义mapper接口就成功了。

    2、设置mapper接口全限定名

这里mapper接口里面的全限定名就是前面定义的名称空间,也就是说一定需要和你sql映射文件中对应sql语句的namespace属性相同。
在这里插入图片描述

    3、定义接口里面的方法

接口里面定义的方法名要和sql映射文件的id属性相同,返回类型要和resultType类型相同。
在这里插入图片描述
在这里插入图片描述

    4、修改sql映射文件为包扫描方式

将mybatis-config.xml的sql映像修改为

	<!--    加载sql映射文件-->
<mappers>
<!--        <mapper resource="com.mybatis.mapper.UserMapper.xml"/>--><package name="mapper接口的包名,例如我的是com.mybatis.mapper"/>
</mappers>

    5、编码

步骤和MyBatis代码大致相同,只有第执行sql语句不同(MyBatis编码参考另一篇博客)
大致步骤如下:
1.创建一个对应的数据库的实体类,我数据库里面存放的是用户信息,所以我定义了一个User类。
2.将以下代码放在你的测试类或者自己定义的类里面
第一行主要用于获取驱动以及连接路径(我们在第二步配置核心文件里面已经配置了)
第二行就是把数据库的资源加载到一个字节输入流里面
第三行建立一个sqlSessionFactory对象,用于后面sql语句的执行

    String resource = "mybatis-config.xml";InputStream inputStream = Resources.getResourceAsStream(resource);SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

3.获取SqlSession对象,用来执行sql语句

	        SqlSession sqlSession = sqlSessionFactory.openSession();

4.执行sql

	//mapper代理就第三步和MyBatis不同UserMapper mapper = sqlSession.getMapper(UserMapper.class);List<User> users = mapper.selectAll();

5.释放资源

package com.mybatis.demo;import com.mybatis.mapper.UserMapper;
import com.mybatis.pojo.User;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.InputStream;
import java.util.List;public class MyBatis002 {public static void main(String[] args) throws Exception {
//        1.加载核心配置文件,获取sqlSessionFactory对象String resource = "mybatis-config.xml";InputStream inputStream = Resources.getResourceAsStream(resource);SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//        2.获取SQLSession对象SqlSession sqlSession = sqlSessionFactory.openSession();
//        3.执行sql
//        List<User> user = sqlSession.selectList("mybatis.selectAll");
//        mapper代理就第三步和MyBatis不同UserMapper mapper = sqlSession.getMapper(UserMapper.class);List<User> users = mapper.selectAll();System.out.println(users);//        4.释放资源sqlSession.close();}
}

在这里插入图片描述

二、mybatisx插件的安装

    1、下载

在这里插入图片描述
在这里插入图片描述

然后点击apply,就可以了。如果点击后没有效果,就重新启动idea试一下。

    2、使用

如果出现蓝色或者红色小鸟,说明插件安装成功。
在这里插入图片描述
使用的时候主要有两个功能:
1.实现接口和sql映射文件的跳转。比如我需要找UserMapper的sql映射文件,只需要点一下红色小鸟就行了。如果需要找到映射文件对应的接口,只需要点一下蓝色小鸟。
在这里插入图片描述
在这里插入图片描述
2.定义接口时自动生成对应名称sql映射文件。
如我需要生成一个selectByuserName()方法,只需要点击Alt+enter,点击create statement。
插件可以自动给你生成sql映射文件框架,只需要你写里面的sql语句。
在这里插入图片描述
在这里插入图片描述
OK,mapper代理开发和mybatisx插件使用就介绍完了。

这篇关于MyBatis--Mapper代理开发和MyBatisX插件使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/350591

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

mybatis映射器配置小结

《mybatis映射器配置小结》本文详解MyBatis映射器配置,重点讲解字段映射的三种解决方案(别名、自动驼峰映射、resultMap),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定... 目录select中字段的映射问题使用SQL语句中的别名功能使用mapUnderscoreToCame

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java