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

相关文章

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

Windows下C++使用SQLitede的操作过程

《Windows下C++使用SQLitede的操作过程》本文介绍了Windows下C++使用SQLite的安装配置、CppSQLite库封装优势、核心功能(如数据库连接、事务管理)、跨平台支持及性能优... 目录Windows下C++使用SQLite1、安装2、代码示例CppSQLite:C++轻松操作SQ

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

mapstruct中的@Mapper注解的基本用法

《mapstruct中的@Mapper注解的基本用法》在MapStruct中,@Mapper注解是核心注解之一,用于标记一个接口或抽象类为MapStruct的映射器(Mapper),本文给大家介绍ma... 目录1. 基本用法2. 常用属性3. 高级用法4. 注意事项5. 总结6. 编译异常处理在MapSt

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可