MyBatis(XML映射器操作)

devtools/2024/10/21 5:51:27/
xmlns="http://www.w3.org/2000/svg" style="display: none;">

文章目录

    • 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_2">XML映射器操作(XxxMapper.xml

文件目录

image-20240304162123528

1.基本介绍
1.优点

image-20240304102427876

2.常用顶级元素

image-20240304102444648

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

image-20240304103035583

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

image-20240304103249466

3.创建基本目录

image-20240304104018475

xml_32">4.父模块的pom.xml
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
mybatisconfigxml_101">6.mybatis-config.xml
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);}
xml_229">2.MonsterMapper.xml
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);
xml_306">2.MonsterMapper.xml添加实现类
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);
xml_342">2.MonsterMapper.xml
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);
xml_377">2.MonsterMapper.xml
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();
}
xml_507">4.UserMapper.xml
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

xml_565">6.使用resultMap替换resultType解决,修改UserMapper.xml
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


http://www.ppmy.cn/devtools/27752.html

相关文章

基于python的舞蹈经验分享交流网站django+vue

1.运行环境&#xff1a;python3.7/python3.8。 2.IDE环境&#xff1a;pycharmmysql5.7/8.0; 3.数据库工具&#xff1a;Navicat11 4.硬件环境&#xff1a;windows11/10 8G内存以上 5.数据库&#xff1a;MySql 5.7/8.0版本&#xff1b; 运行成功后&#xff0c;在浏览器中输入&am…

【高质量】2024五一数学建模C题保奖思路+代码(后续会更新)

你的点赞收藏是我后续更新的最大动力&#xff01; 一定要点击文末的卡片&#xff0c;那是获取资料的入口&#xff01; 你是否在寻找数学建模比赛的突破点&#xff1f; 作为经验丰富的数学建模团队&#xff0c;我们将为你带来2024 年五一数学建模&#xff08;C题&#xff09;…

利用R语言自带函数快速探索数据

《R Graphics Cookbook》 chapter2 Quickly Exploring Data 快速浏览数据 为了非常快速地浏览数据&#xff0c;有时使用 R 自带的绘图函数很有用 Creating a Scatter Plot 创建一个散点图 要制作散点图&#xff0c;请使用 plot() 并向其传递一个 x 值的向量&#xff0c;后跟一…

为什么我的Mac运行速度变慢 mac运行速度慢怎么办 如何使用CleanMyMac X修复它

近些年伴随着苹果生态的蓬勃发展&#xff0c;越来越多的用户开始尝试接触Mac电脑。然而很多人上手Mac后会发现&#xff0c;它的使用逻辑与Windows存在很多不同&#xff0c;而且随着使用时间的增加&#xff0c;一些奇奇怪怪的文件也会占据有限的磁盘空间&#xff0c;进而影响使用…

力扣-977.有序数组的平方

class Solution:def sortedSquares(self, nums: List[int]) -> List[int]:# 使用列表推导式计算每个数字的平方&#xff0c;并排序后返回return sorted(num * num for num in nums)思路&#xff1a; 这段代码实现了一个函数 sortedSquares&#xff0c;它接受一个整数列表 n…

web3以太坊开发,前后端交互中涉及到的合约

在web3以太坊开发中&#xff0c;往往大家交流的时候&#xff0c;会涉及到一些合约相关的词汇&#xff0c;这里重点说两个合约&#xff0c;一个是manager合约&#xff0c;另一个是registry合约。 目录 1 Manager合约 2 Registry合约 2.1 Registry合约可以做什么&#xff1f; …

SpringMVC执行流程

SpringMVC的执行流程&#xff08;介绍核心组件&#xff09; SpringMVC是一个基于Java的开源Web应用程序开发框架&#xff0c;它遵循了MVC&#xff08;Model-View-Controller&#xff09;架构模式。MVC模式是一种将应用程序分为三个主要部分的设计模式&#xff0c;分别是模型&am…

STM32 HAL库F103系列之IIC实验

IIC总线协议 IIC总线协议介绍 IIC&#xff1a;Inter Integrated Circuit&#xff0c;集成电路总线&#xff0c;是一种同步 串行 半双工通信总线。 总线就是传输数据通道 协议就是传输数据的规则 IIC总线结构图 ① 由时钟线SCL和数据线SDA组成&#xff0c;并且都接上拉电阻…