Java中mybatis的Mpper代理开发的详细使用步骤

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: mybatis使用Mapper代理开发会更加的方便,一般推荐这样的方式,形式和mapper常规使用也差不多

mybatis使用Mapper代理开发会更加的方便,一般推荐这样的方式,形式和mapper常规使用也差不多


其他说明:还有注解的方式可以调用,不过注解的方式只能应用于简单的sql语句,复杂的语句就要用文中的xml调用方式了


使用配置:

以下的安装配置的超链接,如有需要可用去查看

IDEA:2022

JDK:17

项目结构:maven

图中小鸟插件:mybatisx

一、全图预览

二、使用步骤

1.pom.xml里面添加依赖包  


先在maven架构的pom.xml里面添加要使用的mybatismysql两个依赖(俗称jar包)

    <dependencies>
        <!--mybatis依赖包-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.11</version>
        </dependency>
        <!--mysql依赖包-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.30</version>
        </dependency>
    </dependencies>

如图所示:


2.新建统一配置文件(俗称数据库连接文件)

(1)在resources下--新建--文件(选择第2个)---mybatis-config.xml


ps:这里面是用来连接数据库的统一配置文件



2)把这个配置信息添加到这个新建的配置文件里面


ps:这个配置文件在mybatis官网的入门那里有

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <!--数据库信息-->
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/><!--改:数据库的固定连接,老版本不用cj-->
                <property name="url" value="jdbc:mysql://localhost:3306/javafx"/><!--改数据库的要连接的库-->
                <property name="username" value="root"/><!--改:数据库的账号-->
                <property name="password" value="123456"/><!--改:数据库的密码-->
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <!--加载映射文件-->
        <mapper resource="com/project/Mapper/boyMapper.xml"/><!--改:把映射文件的源根路径复制到这里-->
    </mappers>
</configuration>

如图所示:


3.新建项目

(1)要在java的项目下面建立2个包,一个是接口包Mapper,一个是封装包pojo


com.project:项目名


Mapper:接口包


pojo:实现类包



(2)


封装包pojo里面建立一个和数据库对应的封装类--Boy


接口包Mapper下建立一个接口--boyMapper


ps:数据库图(这个是为了方便对应参考,知道那些类名是怎么来的)



Boy里面是封装属性。然后快捷键生成的set和get、构造方法、toString)



boyMapper(接口起这个名字是为了和接下来的resources里面的xml映射文件名一样)

ps:并在接口里面定义一个查询全部的集合方法-


4.新建映射文件(俗称数据库对应表xml)

(1)在resources下--新建--目录包---com/project/Mapper


格式:

新建一个目录包和接口包一样的名称就好了。建立输入时候注意:小点那个要用/代替才能建立成功


ps:这样做的目的就是为了xml文件和接口包在同一个文件下


如图所示



(2)在resources下新建好的包下建立一个boyMapper.xml文件,并在里面写上对应的映射方法


格式

数据库要操作对应的表名Mapper.xml,以后数据库的操作语句都在这个映射文件里面写就好了


添加进去的映射方法

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--映射查询方法-->
<mapper namespace="com.project.Mapper.boyMapper"><!--namespace=对应接口的全部路径-->
    <select id="selectAll" resultType="com.project.pojo.Boy"><!--参数一:接口对应的方法名    参数二:封装类的详细地址-->
        select * from boy;<!--要执行的sql语句-->
    </select>
</mapper>

如图所示


5.测试

编写一个测试类,放哪里测试都可以(我在pojo里面建立)

package com.project.pojo;
import com.project.Mapper.boyMapper;
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.IOException;
import java.io.InputStream;
import java.util.List;
public class BoyTest {
    public static void main(String[] args) throws IOException {
        //1.加载mybatis连接文件(核心配置文件)
        String resource = "mybatis-config.xml";//这是连接数据库的统一配置xml文件
        InputStream inputStream = Resources.getResourceAsStream(resource);//固定写法
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);//固定写法
        //2.获取SqlSessionFactory对象--固定写法
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //3.执行sql语句
        //接口 自定义接口名 = sqlSession.getMapper(接口.class);
        boyMapper boyMapper = sqlSession.getMapper(boyMapper.class);
        //接口里面的方法
        List<Boy> boyAll = boyMapper.selectAll();
        //4.打印语句
        System.out.println(boyAll);
        //5.释放资源--固定写法
        sqlSession.close();
    }
}

运行结果:

[boy{id=1, name='小明', age=18}, boy{id=2, name='小美', age=19}]

三、文中的全部代码(去复制可用)

超链接

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
15天前
|
监控 JavaScript 前端开发
《理解 WebSocket:Java Web 开发的实时通信技术》
【4月更文挑战第4天】WebSocket是Java Web实时通信的关键技术,提供双向持久连接,实现低延迟、高效率的实时交互。适用于聊天应用、在线游戏、数据监控和即时通知。开发涉及服务器端实现、客户端连接及数据协议定义,注意安全、错误处理、性能和兼容性。随着实时应用需求增加,WebSocket在Java Web开发中的地位将更加重要。
|
1天前
|
安全 Java API
java借助代理ip,解决访问api频繁导致ip被禁的问题
java借助代理ip,解决访问api频繁导致ip被禁的问题
|
1天前
|
前端开发 Java Go
开发语言详解(python、java、Go(Golong)。。。。)
开发语言详解(python、java、Go(Golong)。。。。)
|
1天前
|
人工智能 前端开发 Java
Java语言开发的AI智慧导诊系统源码springboot+redis 3D互联网智导诊系统源码
智慧导诊解决盲目就诊问题,减轻分诊工作压力。降低挂错号比例,优化就诊流程,有效提高线上线下医疗机构接诊效率。可通过人体画像选择症状部位,了解对应病症信息和推荐就医科室。
27 10
|
1天前
|
Java 关系型数据库 MySQL
一套java+ spring boot与vue+ mysql技术开发的UWB高精度工厂人员定位全套系统源码有应用案例
UWB (ULTRA WIDE BAND, UWB) 技术是一种无线载波通讯技术,它不采用正弦载波,而是利用纳秒级的非正弦波窄脉冲传输数据,因此其所占的频谱范围很宽。一套UWB精确定位系统,最高定位精度可达10cm,具有高精度,高动态,高容量,低功耗的应用。
一套java+ spring boot与vue+ mysql技术开发的UWB高精度工厂人员定位全套系统源码有应用案例
|
7天前
|
SQL Java 数据库连接
MyBatis精髓揭秘:Mapper代理实现的黑盒探索
MyBatis精髓揭秘:Mapper代理实现的黑盒探索
16 1
|
8天前
|
运维 NoSQL 算法
Java开发-深入理解Redis Cluster的工作原理
综上所述,Redis Cluster通过数据分片、节点发现、主从复制、数据迁移、故障检测和客户端路由等机制,实现了一个分布式的、高可用的Redis解决方案。它允许数据分布在多个节点上,提供了自动故障转移和读写分离的功能,适用于需要大规模、高性能、高可用性的应用场景。
16 0
|
10天前
|
人工智能 小程序 Java
JAVA开发智慧学校系统源码+人脸电子班牌布局
智慧校园是通过利用物联网,大数据技术来改变师生和校园资源相互交互的方式,以便提高交互的明确性、灵活性和响应速度,从而实现智慧化服务和管理的校园模式。
|
13天前
|
Java
在Java中,定义一个接口的步骤如下
【4月更文挑战第6天】在Java中,定义一个接口的步骤如下
5 1
|
16天前
|
XML JSON JavaScript
使用JSON和XML:数据交换格式在Java Web开发中的应用
【4月更文挑战第3天】本文比较了JSON和XML在Java Web开发中的应用。JSON是一种轻量级、易读的数据交换格式,适合快速解析和节省空间,常用于API和Web服务。XML则提供更强的灵活性和数据描述能力,适合复杂数据结构。Java有Jackson和Gson等库处理JSON,JAXB和DOM/SAX处理XML。选择格式需根据应用场景和需求。