总结 MyBatis 的XML实现方法(使用XML使用实现数据的增删改查操作)

MyBatis是一个优秀的持久层框架,它的XML配置文件是实现数据库操作的关键之一。通过XML文件,可以定义SQL语句、映射关系和一些高级功能。下面将探讨下如何使用MyBatis的XML配置文件实现数据的增、删、改、查操作。

1.配置文件

首先要确保 mybatis-config.xml 配置文件中引入了映射文件的路径:

java 复制代码
<!-- mybatis-config.xml -->
<configuration>
    <!-- 其他配置 -->
    <mappers>
        <mapper resource="com/example/mappers/UserMapper.xml"/>
        <!-- 其他映射文件 -->
    </mappers>
</configuration>

2.增加数据

在UserMapper.xml文件中,使用insert元素定义插入数据的SQL语句:

java 复制代码
<!-- UserMapper.xml -->
<mapper namespace="com.example.mappers.UserMapper">
    <!-- 插入数据 -->
    <insert id="insertUser" parameterType="com.example.model.User">
        INSERT INTO users (id, username, email) VALUES (#{id}, #{username}, #{email})
    </insert>
</mapper>

上述例子中,#{id}、#{username}、#{email}是占位符,MyBatis会根据传入的User对象的属性值进行替换。

3.查询数据

使用select元素定义查询数据的SQL语句:

java 复制代码
<!-- UserMapper.xml -->
<mapper namespace="com.example.mappers.UserMapper">
    <!-- 查询数据 -->
    <select id="selectUserById" parameterType="int" resultType="com.example.model.User">
        SELECT * FROM users WHERE id = #{id}
    </select>
</mapper>

在这个例子中,parameterType指定了传入SQL语句的参数类型,resultType指定了返回结果的类型。

4.更新数据

使用update元素定义更新数据的SQL语句:

java 复制代码
<!-- UserMapper.xml -->
<mapper namespace="com.example.mappers.UserMapper">
    <!-- 更新数据 -->
    <update id="updateUser" parameterType="com.example.model.User">
        UPDATE users SET username = #{username}, email = #{email} WHERE id = #{id}
    </update>
</mapper>

5. 删除数据

使用delete元素定义删除数据的SQL语句:

java 复制代码
<!-- UserMapper.xml -->
<mapper namespace="com.example.mappers.UserMapper">
    <!-- 删除数据 -->
    <delete id="deleteUser" parameterType="int">
        DELETE FROM users WHERE id = #{id}
    </delete>
</mapper>

6. 参数传递

在上述例子中,使用#{}占位符来传递参数。MyBatis支持多种参数传递方式,包括#{}占位符、${}占位符、@Param注解等。

相关推荐
IronMurphy9 小时前
SSM拷打第二讲!!!
java·spring·mybatis
祭曦念15 小时前
ArkUI声明式UI入门:从XML到声明式的思维转变
xml·ui·鸿蒙
C+-C资深大佬1 天前
SSM 框架(Spring + SpringMVC + MyBatis)
java·spring·mybatis
二王一个今1 天前
springboot security 权限控制---循环依赖问题
mybatis
落木萧萧8252 天前
为什么我把 MyBatisGX 设计成现在这样
mybatis·orm
代码旅人ing2 天前
Redis+Spring+MyBatis + 微服务 + 消息队列核心知识点(面试高频题目合集)
redis·spring·mybatis·java-rabbitmq
Devin~Y2 天前
大厂Java面试实录:Spring Boot/Cloud、Kafka、Redis、K8s 可观测性 + RAG/Agent(小Y翻车版)
java·spring boot·redis·spring cloud·kafka·kubernetes·mybatis
ppandss12 天前
JavaWeb从0到1-DAY11-MyBatis入门
java·tomcat·mybatis
Meteors.2 天前
安卓源码阅读——01.grade设置binding为true时,xml如何进行映射
android·xml
JAVA面经实录9172 天前
MyBatis面试题库
java·mybatis