MyBatis(XML映射器操作)

news2025/2/23 18:35:11

文章目录

    • XML映射器操作(XxxMapper.xml)
        • 文件目录
        • 1.基本介绍
          • 1.优点
          • 2.常用顶级元素
        • 2.环境配置
          • 1.在原来的父模块下创建一个子模块
          • 2.删除没用的两个文件夹
          • 3.创建基本目录
          • 4.父模块的pom.xml
          • 5.jdbc.properties
          • 6.mybatis-config.xml
          • 7.测试使用MonsterMapperTest.java
        • 3.parameterType(输入参数类型)
          • 1.基本介绍
          • 2.案例一
            • 1.MonsterMapper.java
            • 2.MonsterMapper.xml
            • 3.测试
          • 3.案例二(模糊查询)
            • 1.MonsterMapper.java添加方法
            • 2.MonsterMapper.xml添加实现类
            • 3.测试
        • 4.传入HashMap
          • 1.基本介绍![image-20240304135016653](https://img-blog.csdnimg.cn/img_convert/6ece40de84bcc9416cce823c98dd14c1.png)
          • 2.案例一(参数为map)
            • 1.MonsterMapper.java添加方法
            • 2.MonsterMapper.xml
            • 3.测试
          • 3.案例二(返回值为map)
            • 1.MonsterMapper.java添加方法
            • 2.MonsterMapper.xml
            • 3.测试
        • 5.ResultMap
          • 1.基本介绍
          • 2.案例
            • 1.创建数据表
            • 2.创建映射类User.java
            • 3.UserMapper.java
            • 4.UserMapper.xml
            • 5.测试(数据未填充!)
            • 6.使用resultMap替换resultType解决,修改UserMapper.xml
            • 7.结果
          • 3.注意事项与细节

XML映射器操作(XxxMapper.xml)

文件目录

image-20240304162123528

1.基本介绍
1.优点

image-20240304102427876

2.常用顶级元素

image-20240304102444648

2.环境配置
1.在原来的父模块下创建一个子模块

image-20240304103035583

2.删除没用的两个文件夹

image-20240304103249466

3.创建基本目录

image-20240304104018475

4.父模块的pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>org.example</groupId>
  <artifactId>mybatis</artifactId>
  <version>1.0-SNAPSHOT</version>
  <packaging>pom</packaging>
  <name>Archetype - mybatis</name>
  <url>http://maven.apache.org</url>
  <modules>
    <module>mybatis_quickstart</module>
    <module>xml-mapper</module>
  </modules>
  <dependencies>
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.49</version>
    </dependency>
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.5.7</version>
    </dependency>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.12</version>
      <!--如果设置scope为test,则只能在test包下使用-->
      <scope>test</scope>
    </dependency>
  </dependencies>
  <!--在父模块中的pom.xml文件中配置在build的时候要扫描的文件,解决某些类型文件拷贝到target目录失败的问题-->
  <build>
    <resources>
      <resource>
        <directory>src/main/java</directory>
        <includes>
          <!--在java文件夹下的多级目录下的xml文件-->
          <include>**/*.xml</include>
        </includes>
      </resource>
      <resource>
        <directory>src/main/resources</directory>
        <includes>
          <!--在resources文件夹下的多级目录下的xml文件和properties文件-->
          <include>**/*.xml</include>
          <include>**/*.properties</include>
        </includes>
      </resource>
    </resources>
  </build>
</project>

5.jdbc.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/mybatis?useSSL=false&amp;useUnicode=true&amp;characterEncoding=UTF-8
jdbc.username=root
jdbc.password=root

6.mybatis-config.xml
<?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>
    <!--引入外部文件jdbc.properties-->
    <properties resource="jdbc.properties"/>

    <!--配置mybatis自带的日志,settings需要放到最前面-->
    <settings>
        <setting name="logImpl" value="STDOUT_LOGGING"/>
    </settings>

    <!--配置类型别名-->
    <typeAliases>
        <!--方式二:这样配置完了在这个包下的所有类都可以直接使用类名表示-->
        <package name="com.sun.entity"/>
    </typeAliases>

    <environments default="development">
        <environment id="development">
            <!--配置事务管理器-->
            <transactionManager type="JDBC"/>
            <!--配置数据源-->
            <dataSource type="POOLED">
                <!--配置驱动-->
                <property name="driver" value="${jdbc.driver}"/>
                <!--配置连接url-->
                <!--
                1.jdbc:mysql:协议
                2.127.0.0.1:3306:指定连接mysql的ip+端口
                3.mybatis:连接的db
                4.useSSL:使用安全连接
                5.&amp;:表示&
                6.useUnicode=true:使用unicode,防止编码错误
                7.characterEncoding=UTF-8:字符集使用utf-8
                -->
                <property name="url" value="${jdbc.url}"/>
                <!--用户名-->
                <property name="username" value="${jdbc.username}"/>
                <!--密码-->
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>
    </environments>

    <mappers>
        <!--包的方式引入含有Mapper.xml的类-->
        <package name="com.sun.mapper"/>
    </mappers>

</configuration>

7.测试使用MonsterMapperTest.java
package com.sun.mapper;

import com.util.MyBatisUtils;
import org.apache.ibatis.session.SqlSession;
import org.junit.Before;
import org.junit.Test;

/**
 * @author 孙显圣
 * @version 1.0
 */
public class MonsterMapperTest {
    //两个属性
    private SqlSession sqlSession; //相当于连接
    private MonsterMapper monsterMapper;

    //编写方法完成初始化
    @Before //标注了Before之后表示了在执行目标测试方法前会执行该方法
    public void init() {
        //获取到sqlSession
        sqlSession = MyBatisUtils.getSqlSession();
        //获取到MonsterMapper对象
        monsterMapper = sqlSession.getMapper(MonsterMapper.class);
        System.out.println(monsterMapper.getClass());
    }
    @Test
    public void test() {
        System.out.println("ssss");
    }
}

image-20240304105411141

3.parameterType(输入参数类型)
1.基本介绍

image-20240304105809901

2.案例一
1.MonsterMapper.java
package com.sun.mapper;


import com.sun.entity.Monster;

import java.util.List;

/**
 * 这个接口用于声明操作monster表的方法
 *
 * @author 孙显圣
 * @version 1.0
 */
public interface MonsterMapper {
    //通过id或者名字查询
    public List<Monster> findMonsterByNameORId(Monster monster);

}

2.MonsterMapper.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">
<!--指定该xml文件和哪个接口对应-->
<mapper namespace="com.sun.mapper.MonsterMapper">
    <!--实现public List<Monster> findMonsterByNameORId(Monster monster);
	这里能直接写Monster是因为配置文件里配置了类型别名
	-->
    <select id="findMonsterByNameORId" parameterType="Monster" resultType="Monster">
        SELECT * FROM monster WHERE id = #{id} OR `name` = #{name}
    </select>
</mapper>
3.测试
package com.sun.mapper;

import com.sun.entity.Monster;
import com.util.MyBatisUtils;
import org.apache.ibatis.session.SqlSession;
import org.junit.Before;
import org.junit.Test;

import java.util.List;

/**
 * @author 孙显圣
 * @version 1.0
 */
public class MonsterMapperTest {
    //两个属性
    private SqlSession sqlSession; //相当于连接
    private MonsterMapper monsterMapper;

    //编写方法完成初始化
    @Before //标注了Before之后表示了在执行目标测试方法前会执行该方法
    public void init() {
        //获取到sqlSession
        sqlSession = MyBatisUtils.getSqlSession();
        //获取到MonsterMapper对象
        monsterMapper = sqlSession.getMapper(MonsterMapper.class);
        System.out.println(monsterMapper.getClass());
    }
    @Test
    public void test() {
        Monster monster = new Monster();
        monster.setId(1);
        monster.setName("大象精");
        List<Monster> monsterList = monsterMapper.findMonsterByNameORId(monster);
        for (Monster monster1 : monsterList) {
            System.out.println(monster1);
        }
        //关闭sqlsession
        if (sqlSession != null) {
            sqlSession.close();
        }
    }
}

image-20240304111611381

3.案例二(模糊查询)
1.MonsterMapper.java添加方法
    public List<Monster> findMonsterByName(String name);
2.MonsterMapper.xml添加实现类
    <!--实现public List<Monster> findMonsterByName(String name);-->
    <select id="findMonsterByName" parameterType="String" resultType="Monster">
        SELECT * FROM monster WHERE `name` LIKE '%${name}%'
    </select>
3.测试
    @Test
    public void MonsterMapper() {
        List<Monster> monsterList = monsterMapper.findMonsterByName("孙");
        for (Monster monster : monsterList) {
            System.out.println(monster);
        }
    }

image-20240304134750221

4.传入HashMap
1.基本介绍image-20240304135016653
2.案例一(参数为map)
1.MonsterMapper.java添加方法
    //传入map
    public List<Monster> findMonsterByIdAndName_ParamMap(Map<String, Object> map);
2.MonsterMapper.xml
    <!--这里如果想要获取到id和name则需要这个Map里面有这两个key-->
    <select id="findMonsterByIdAndName_ParamMap" parameterType="Map" resultType="Monster">
        SELECT * FROM monster WHERE id = #{id} OR `name` = #{name}
    </select>
3.测试
    @Test
    public void findMonsterByIdAndName_ParamMap() {
        Map map = new HashMap<String, Object>();
        map.put("id", 1);
        map.put("name", "大象精");
        List<Monster> monsters = monsterMapper.findMonsterByIdAndName_ParamMap(map);
        for (Monster monster : monsters) {
            System.out.println(monster);
        }
    }

image-20240304140423827

3.案例二(返回值为map)
1.MonsterMapper.java添加方法
    //以map作为返回参数
    public List<Map<String, Object>> findMonsterByIdAndName_ParamMap_returnMap(Map<String, Object> map);
2.MonsterMapper.xml
    <!--返回值是List,每一个元素都是一个map,而一个map代表了一条记录,key代表列,value代表值-->
    <select id="findMonsterByIdAndName_ParamMap_returnMap" parameterType="Map" resultType="Map">
        SELECT * FROM monster WHERE id = #{id} OR `name` = #{name}
    </select>
3.测试
    @Test
    public void findMonsterByIdAndName_ParamMap_returnMap() {
        Map map = new HashMap<String, Object>();
        map.put("id", 6);
        map.put("name", "大象精");
        List<Map<String, Object>> mapList = monsterMapper.findMonsterByIdAndName_ParamMap_returnMap(map);
        //取出所有map
        for (Map<String, Object> stringObjectMap : mapList) {
            for (Map.Entry<String, Object> entry : stringObjectMap.entrySet()) {
                System.out.println(entry.getKey() + " " + entry.getValue());
            }
        }
    }

image-20240304142058962

5.ResultMap
1.基本介绍

image-20240304142524912

2.案例
1.创建数据表
CREATE TABLE `user` (
	user_id INT NOT NULL auto_increment,
	user_email VARCHAR(255) DEFAULT '',
	user_name VARCHAR(255) DEFAULT'',
	PRIMARY KEY (user_id)
)
2.创建映射类User.java
package com.sun.entity;


/**
 * @author 孙显圣
 * @version 1.0
 */

public class User {
    private Integer user_id;
    //下面两个字段与数据表的字段不对应
    private String username; 
    private String useremail;

    public User() {
    }

    public User(Integer user_id, String username, String useremail) {
        this.user_id = user_id;
        this.username = username;
        this.useremail = useremail;
    }

    public Integer getUser_id() {
        return user_id;
    }

    public void setUser_id(Integer user_id) {
        this.user_id = user_id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getUseremail() {
        return useremail;
    }

    public void setUseremail(String useremail) {
        this.useremail = useremail;
    }

    @Override
    public String toString() {
        return "User{" +
                "user_id=" + user_id +
                ", username='" + username + '\'' +
                ", useremail='" + useremail + '\'' +
                '}';
    }
}

3.UserMapper.java
UserMapper.xmlpackage com.sun.mapper;

import com.sun.entity.User;

import java.util.List;

/**
 * @author 孙显圣
 * @version 1.0
 */
public interface UserMapper {
    //查询所有UserMapper.xmlser
    public List<User> findAllUser();
}

4.UserMapper.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">
<!--指定该xml文件和哪个接口对应-->
<mapper namespace="com.sun.mapper.UserMapper">
    <select id="findAllUser" resultType="User">
        SELECT * FROM user
    </select>
</mapper>
5.测试(数据未填充!)
package com.sun.mapper;

import com.sun.entity.User;
import com.util.MyBatisUtils;
import org.apache.ibatis.session.SqlSession;
import org.junit.Before;
import org.junit.Test;

import java.util.List;

/**
 * @author 孙显圣
 * @version 1.0
 */
public class UserMapperTest {
    //两个属性
    private SqlSession sqlSession; //相当于连接
    private UserMapper userMapper;

    //编写方法完成初始化
    @Before //标注了Before之后表示了在执行目标测试方法前会执行该方法
    public void init() {
        //获取到sqlSession
        sqlSession = MyBatisUtils.getSqlSession();
        //获取到MonsterMapper对象
        userMapper = sqlSession.getMapper(UserMapper.class);
        System.out.println(userMapper.getClass());
    }

    @Test
    public void findAllUser() {
        List<User> allUser = userMapper.findAllUser();
        System.out.println(allUser);
    }
}

image-20240304145105755

6.使用resultMap替换resultType解决,修改UserMapper.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">
<!--指定该xml文件和哪个接口对应-->
<mapper namespace="com.sun.mapper.UserMapper">
    <!--使用resultMap替换resultType,来进行映射类的属性与表之间的映射-->
    <resultMap id="findAllUserResultType" type="User">
        <result column="user_email" property="useremail"/>
        <result column="user_name" property="username"/>
    </resultMap>
    <select id="findAllUser" resultMap="findAllUserResultType">
        SELECT * FROM user
    </select>
</mapper>
7.结果

image-20240304155238444

3.注意事项与细节
  • 如果没有使用resultMap,但是表的列名与映射类的属性不匹配,则返回的结果不会填充,则该位置会是对象属性的默认值
  • 解决列名与属性名不同也可以使用别名,简单来说就是查询出来结果的时候使用as,将结果所在的列名设置成跟属性一致的名字,但是不推荐
  • MyBatis-Plus可以直接使用@TableField注解或者@TableName注解来解决

image-20240304155904444

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

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

相关文章

芒果超媒财报解读:科技加持下,如何蜕变为内容“全科生”?

在降本增效和内容为王的基调下&#xff0c;国内头部长视频平台正在拥抱增长。 爱奇艺率先公布2023年财务数据&#xff0c;实现归母净利润19.25亿元&#xff0c;与2022年亏损1.36亿元相比&#xff0c;扭亏为盈且增幅显著。 而近日&#xff0c;随着新一季《浪姐》播出&#xff…

一文全面了解 Kaggle 平台:数据科学和机器学习的理想之地

&#x1f349; CSDN 叶庭云&#xff1a;https://yetingyun.blog.csdn.net/ 在数据科学&#xff08;Data Science&#xff09;领域&#xff0c;Kaggle 可以称得上是一座人人都想挑战的高峰。Kaggle 是一个国际知名的数据科学竞赛平台&#xff0c;由 Anthony Goldbloom 和 Ben Ha…

内网神器Cobalt Strike隐藏特征与流量混淆.

由于上次还没有写好https上线的东西&#xff0c;今天加班加点的弄出来了。 本文内容如有错误&#xff0c;望及时告知&#xff0c;以免误导他人. Cobalt Strike 特征隐藏与流量混淆 大致内容&#xff1a; 修改默认端口 服务器设置禁Ping Cobalt Strike默认证书修改 CDN隐藏…

【c++】mutable是一个关键字,用于指定一个类成员可以在一个const成员函数中被修改。

mutable是一个关键字,用于指定一个类成员可以在一个const成员函数中被修改。通常,当一个成员函数被声明为const时,这意味着这个函数不能修改它所属的对象。然而,有时候你可能需要在一个const成员函数中修改某个成员变量。这时,你就可以使用mutable关键字。webrtc的StunReq…

VOS系统录音文件REC转MP3,REC录音转WAV与WAV转MP3具体项目中实现方式,以及占用空间变化!

前面讲解了VOS3000系统的录音REC转MP3的安装步骤&#xff0c;不清楚的&#xff0c;可以移步这里查看&#xff1a;http://t.csdnimg.cn/OXNT9 或者 点击这里查看安装步骤&#xff0c;下面继续讲下他们的使用方法&#xff0c;以及实际项目中的运用&#xff0c;首先我们需要明确我…

记录一下因网络问题导致的安装Python3.8和SuperSet的报错

【报错1】Python3.8的环境报错 【背景说明】 我目前在搭建数仓最后一个环境-->将MySQL的数据用SuperSet展示&#xff0c;安装SuperSet需要提前在Linux上安装Python环境&#xff0c;下面截图就是我在创建Python3.8的环境报错 命令为&#xff1a;(base) [dahuahadoop102 ~]…

shell脚本,删除30天以前的日志,并将日志推送到nas,但运行出现/bin/bash^M。

删除30天以前的日志 将日志推送到nas中&#xff0c;然后删除pod中的日志 pod挂载到本地 运行出现/bin/bash^M 1、删除30天以前的日志&#xff1a; #! /bin/bash# 定义源日志目录 LOG_DIR/home/log/ # 删除日志 find $LOG_DIR -type f -name "*.log" -mtime 30 -exec…

沐风老师3DMAX一键生成桌子插件TableMaker使用方法

3DMAX一键生成桌子插件TableMaker使用教程 3DMAX一键生成桌子插件TableMaker&#xff0c;参数化方式快速创建各种样式桌子模型。 【适用版本】 3dMax2011-2025&#xff08;不仅限于此范围&#xff09; 【安装方法】 3DMAX一键生成桌子插件无需安装&#xff0c;使用时直接拖动…

期权交割对股市是好是坏?2024期权交割日一览表

期权交割是指期权买方在期权合约到期日或之前行使期权&#xff0c;卖方履行义务&#xff0c;按照约定的价格和数量与期权卖方进行标的物的买卖或现金结算的过程。 交割方式 期权交割可以分为实物交割和现金交割&#xff0c;具体取决于合约规定。 实物交割 实物交割是指期权买…

Git推送本地项目到gitee远程仓库

Git 是一个功能强大的分布式版本控制系统&#xff0c;它允许多人协作开发项目&#xff0c;同时有效管理代码的历史版本。开发者可以克隆一个公共仓库到本地&#xff0c;进行更改后将更新推送回服务器&#xff0c;或从服务器拉取他人更改&#xff0c;实现代码的同步和版本控制。…

C#程序带参数运行

总结参数是靠 空格来分割 不同组参数的。 参考链接 C#控制台程序入口函数 Main(string[] args) 参数详解_c#中args-CSDN博客https://blog.csdn.net/xwnxwn/article/details/113802305#:~:text%E5%8F%B3%E9%94%AE%E7%82%B9%E5%87%BB%E3%80%90%E9%A1%B9%E7%9B%AE%E3%80%91--%E3%…

下一代云原生应用引擎OpenNJet体验

文章目录 前言OpenNJet 介绍OpenNJet VS NGINXOpenNJet 安装OpenNJet 动态配置体验动态location动态黑名单动态灰度发布 体验感受 前言 作为一名技术人员&#xff0c;我们应时刻保持对行业动态的关注&#xff0c;今天我们就来体验一下号称下一代云原生应用引擎OpenNJet。 Ope…

2022 csp-j 答案(精选题)

主题目 16 - 21题 22 - 27题 28 - 34题 35 -39题 40 - 44题 精选题目 答案及解析 28题 答案&#xff1a;T 解析&#xff1a;考查时间复杂度评估。 31题 答案&#xff1a;A 解析&#xff1a;模拟即可。 32题 答案&#xff1a;B 解析&#xff1a;模拟即可。 34题 答…

H3C无线控制器查看AP版本是否自动升级

全部网络--无线配置--AP管理--AP全局配置 如果开启了AP版本升级&#xff0c;那么当升级AC无线控制器的时候 &#xff0c; AP也会同时进行升级 命令行&#xff1a; [H3C]wlan auto-ap enable 自动注册 [H3C]wlan auto-persistent enable 自动固化 [Sysname] …

mysql 版本升级 8.0.24升级到 8.0.34

mysql 版本升级 8.0.24升级到 8.0.34 1、官方升级手册必看1.0、官方升级手册必看1.1、理解升级过程会做什么1.2、备份升级前的数据1.3、支持的升级路径(什么版本升级到什么版本)1.3.1、mysql所有版本归纳1.3.2、版本升级选择的原则 1.4、5升级8.0需要注意 了解MySQL 8.0需要注意…

PotatoPie 4.0 实验教程(37) —— FPGA实现摄像头图像二值化闭运算效果

手机扫码 链接直达 https://item.taobao.com/item.htm?ftt&id776516984361 什么是图像闭运算&#xff0c;有什么作用&#xff1f; 图像闭运算是由膨胀操作和腐蚀操作组成的。其作用与图像开运算相反&#xff0c;主要用于填充物体内部的小洞或小孔&#xff0c;平滑物体边…

C语言——每日一题(移除链表元素)

一.前言 今天在leetcode刷到了一道关于单链表的题。想着和大家分享一下。废话不多说&#xff0c;让我们开始今天的知识分享吧。 二.正文 1.1题目要求 1.2思路剖析 我们可以创建一个新的单链表&#xff0c;然后通过对原单链表的遍历&#xff0c;将数据不等于val的节点移到新…

20.哈希表(哈希冲突,闭散列、线性探测,开散列、哈希桶)

1. unordered系列关联式容器 在C98中&#xff0c;STL提供了底层为红黑树结构的一系列关联式容器&#xff0c;在查询时效率可达到log_2 N&#xff0c;即最差情况下需要比较红黑树的高度次&#xff0c;当树中的节点非常多时&#xff0c;查询效率也不理想。最好的查询是&#xff…

【RAG 博客】Haystack 中的 DiversityRanker 与 LostInMiddleRanker 用来增强 RAG pipelines

Blog&#xff1a;Enhancing RAG Pipelines in Haystack: Introducing DiversityRanker and LostInTheMiddleRanker ⭐⭐⭐⭐ 文章目录 Haystack 是什么1. DiversityRanker2. LostInTheMiddleRanker使用示例 这篇 blog 介绍了什么是 Haystack&#xff0c;以及如何在 Haystack 框…

设计模式 基本认识

文章目录 设计模式的作用设计模式三原则设计模式与类图设计模式的分类 设计模式的作用 设计模式是在软件设计过程中针对常见问题的解决方案的一种通用、可重用的解决方案。设计模式提供了一种经过验证的方法&#xff0c;可以帮助开发人员解决特定类型的问题&#xff0c;并在软…