MyBatis(XML映射器操作)

2024-05-01 04:36
文章标签 xml 操作 mybatis 映射器

本文主要是介绍MyBatis(XML映射器操作),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 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 configurationPUBLIC "-//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:连接的db4.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() {//获取到sqlSessionsqlSession = MyBatisUtils.getSqlSession();//获取到MonsterMapper对象monsterMapper = sqlSession.getMapper(MonsterMapper.class);System.out.println(monsterMapper.getClass());}@Testpublic 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 mapperPUBLIC "-//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() {//获取到sqlSessionsqlSession = MyBatisUtils.getSqlSession();//获取到MonsterMapper对象monsterMapper = sqlSession.getMapper(MonsterMapper.class);System.out.println(monsterMapper.getClass());}@Testpublic 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);}//关闭sqlsessionif (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.测试
    @Testpublic 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添加方法
    //传入mappublic 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.测试
    @Testpublic 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.测试
    @Testpublic 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);//取出所有mapfor (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;}@Overridepublic 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.xmlserpublic List<User> findAllUser();
}
4.UserMapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//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() {//获取到sqlSessionsqlSession = MyBatisUtils.getSqlSession();//获取到MonsterMapper对象userMapper = sqlSession.getMapper(UserMapper.class);System.out.println(userMapper.getClass());}@Testpublic 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 mapperPUBLIC "-//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

这篇关于MyBatis(XML映射器操作)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

MyBatis-Plus 中 nested() 与 and() 方法详解(最佳实践场景)

《MyBatis-Plus中nested()与and()方法详解(最佳实践场景)》在MyBatis-Plus的条件构造器中,nested()和and()都是用于构建复杂查询条件的关键方法,但... 目录MyBATis-Plus 中nested()与and()方法详解一、核心区别对比二、方法详解1.and()

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

python删除xml中的w:ascii属性的步骤

《python删除xml中的w:ascii属性的步骤》使用xml.etree.ElementTree删除WordXML中w:ascii属性,需注册命名空间并定位rFonts元素,通过del操作删除属... 可以使用python的XML.etree.ElementTree模块通过以下步骤删除XML中的w:as

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

MySQL追踪数据库表更新操作来源的全面指南

《MySQL追踪数据库表更新操作来源的全面指南》本文将以一个具体问题为例,如何监测哪个IP来源对数据库表statistics_test进行了UPDATE操作,文内探讨了多种方法,并提供了详细的代码... 目录引言1. 为什么需要监控数据库更新操作2. 方法1:启用数据库审计日志(1)mysql/mariad

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-

XML重复查询一条Sql语句的解决方法

《XML重复查询一条Sql语句的解决方法》文章分析了XML重复查询与日志失效问题,指出因DTO缺少@Data注解导致日志无法格式化、空指针风险及参数穿透,进而引发性能灾难,解决方案为在Controll... 目录一、核心问题:从SQL重复执行到日志失效二、根因剖析:DTO断裂引发的级联故障三、解决方案:修复

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指