使用XML实现MyBatis的基础操作

目录

前言

1.准备工作

1.1⽂件配置

[1.2添加 mapper 接⼝](#1.2添加 mapper 接⼝)

2.增删改查操作

2.1增(Insert)

2.2删(Delete)

2.3改(Update)

2.4查(Select)


前言

接下来我们会使用的数据表如下:

对应的实体类为:UserInfo

所有的准备工作都在如下文章。

MyBatis 操作数据库入门-CSDN博客文章浏览阅读568次,点赞11次,收藏24次。什么是MyBatis?MyBatis是⼀款优秀的 持久层 框架,⽤于简化JDBC的开发Mybatis操作数据库的入门步骤:1.创建springboot⼯程2.数据库表准备、实体类3.引⼊Mybatis的相关依赖,配置Mybatis(数据库连接信息)4.编写SQL语句(注解/XML) ,进行测试了解更多MyBatis中文网1.创建springboot⼯程创建springboot⼯程,并导⼊ mybatis的起步依赖、mysql的驱动包。https://blog.csdn.net/WHabc2002/article/details/142743762


1.准备工作

1.1⽂件配置

如果是application.yml⽂件, 配置内容如下:

复制代码
mybatis:
  mapper-locations: classpath:mybatis/**Mapper.xml

如果是application.properties⽂件, 配置内容如下:

复制代码
mybatis.mapper-locations=classpath:mapper/**Mapper.xml

按照mybatis.mapper-locations设置文件

起名无所谓最后以Mapper.xml结尾就行

1.2添加 mapper 接⼝

数据持久层的接⼝定义:(接口名自已决定)

复制代码
import com.wh.myBatis.model.UserInfo;
import org.apache.ibatis.annotations.Mapper;

import java.util.List;

@Mapper
public interface UserInfoXmlMapper {
    List<UserInfo> selectAllUser();
}

1.3添加MyBatis 的固定 xml 格式

在mybatis.mapper-locations的路径下

加MyBatis 的固定 xml 格式

以我为例:

复制代码
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.wh.myBatis.mapper.UserInfoXmlMapper">

</mapper>

路径一定要正确


2.增删改查操作

为了增加开发效率,我们可以使用插件。

2.1增(Insert)

复制代码
UserInfoXmlMapper接口
复制代码
Integer insert(UserInfo userInfo);

UserInfoXmlMapper.xml的实现

复制代码
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.wh.myBatis.mapper.UserInfoXmlMapper">
    <insert id="insert">
        insert into userinfo (username, password, age, gender)
        values (#{username},#{password},#{age},#{gender})
    </insert>
</mapper>

如果使⽤@Param设置参数名称的话, 使⽤⽅法和注解类似
返回⾃增 id
接⼝定义不变, UserInfoXmlMapper.xml 实现 设置useGeneratedKeys 和keyProperty属性

复制代码
    <insert id="insert2" useGeneratedKeys="true" keyProperty="id">
        insert into userinfo (username, password, age, gender)
        values (#{username},#{password},#{age},#{gender})
    </insert>

2.2删(Delete)

UserInfoXmlMapper接口

复制代码
Integer delete(Integer id);

UserInfoXmlMapper.xml的实现

复制代码
<delete id="delete">
        delete from userinfo where id = #{id}
    </delete>

2.3改(Update)

UserInfoXmlMapper接口

复制代码
Integer update(UserInfo userInfo);

UserInfoXmlMapper.xml的实现

复制代码
  <update id="update">
        update userinfo set username=#{username} where id=#{id}
    </update>

2.4查(Select)

UserInfoXmlMapper接口

复制代码
List<UserInfo> selectAllUser();

UserInfoXmlMapper.xml的实现

复制代码
    <select id="selectAllUser" resultType="com.wh.myBatis.model.UserInfo">
        select * from userinfo
    </select>

MyBatis 会获取结果中返回的列名并在 Java 类中查找相同名字的属性

小驼峰与蛇形的结果映射

UserInfoXmlMapper.xml的实现

复制代码
    <resultMap id="BaseMap" type="com.wh.myBatis.model.UserInfo">
        <id column="id" property="id"></id>
        <result column="delete_flag" property="deleteFlag"></result>
        <result column="create_time" property="createTime"></result>
        <result column="update_time" property="updateTime"></result>
    </resultMap>
    <select id="selectAllUser2" resultMap="BaseMap">
        select * from userinfo
    </select>

以上为我个人的小分享,如有问题,欢迎讨论!!!

都看到这了,不如关注一下,给个免费的赞

相关推荐
烤麻辣烫20 分钟前
23种设计模式(新手)-7迪米特原则 合成复用原则
java·开发语言·学习·设计模式·intellij-idea
鹿里噜哩31 分钟前
Spring Authorization Server 打造认证中心(一)项目搭建/集成
java·后端·spring
菠菠萝宝42 分钟前
【Java手搓RAGFlow】-1- 环境准备
java·开发语言·人工智能·llm·openai·rag
Chan1642 分钟前
热点数据自动缓存方案:基于京东 Hotkey 实践
java·数据库·redis·mysql·spring·java-ee·intellij-idea
汤姆yu43 分钟前
基于springboot的智慧家园物业管理系统
java·spring boot·后端
j***29481 小时前
【SpringBoot】【log】 自定义logback日志配置
java·spring boot·logback
e***0961 小时前
【Spring】配置文件的使用
java·后端·spring
a***13141 小时前
【spring专题】编译spring5.3源码
java·后端·spring
n***63271 小时前
【spring】Spring事件监听器ApplicationListener的使用与源码分析
java·后端·spring
i***48611 小时前
【spring专题】编译spring5.3源码
java·后端·spring