MyBatis常用的XML标签

一、常用的标签

MyBatis 是一个持久层框架,它通过 XML 或注解配置,将 Java 对象与 SQL 语句进行映射。以下是 MyBatis 中常用的一些 XML 标签:

1、<mapper>: 标识 MyBatis 映射器 XML 文件的根元素。

2、<select>: 用于执行查询操作的标签,可以获取一条记录或多条记录。

3、<insert>: 用于执行插入操作的标签,将数据插入到数据库中。

4、<update>: 用于执行更新操作的标签,更新数据库中的数据。

5、<delete>: 用于执行删除操作的标签,从数据库中删除数据。

6、<resultMap>: 用于定义结果集与 Java 对象之间的映射关系,可以定义复杂的映射关系。

7、<parameterMap> : 用于定义参数与 SQL 语句中的参数映射关系,已经被 <parameterType> 取代,不再推荐使用。

8、<sql>: 用于定义 SQL 片段,可以在多个 SQL 语句中重复使用。

9、<include>: 用于包含其他 SQL 片段或者外部 SQL 文件中的内容。

10、<if><choose><when><otherwise>: 用于在 SQL 查询中实现条件判断和分支选择。

11、<foreach>: 用于在 SQL 查询中遍历集合或数组参数,生成多条 SQL 语句。

这些是 MyBatis 中常用的 XML 标签,通过它们可以灵活地配置 SQL 查询、映射关系和条件逻辑,完成数据库操作。

二、使用方法

1、**<mapper>**标签

XML 复制代码
<!-- userMapper.xml -->
<mapper namespace="com.example.UserMapper">
    <!-- SQL语句和其他标签在这里定义 -->
</mapper>

2、<select> 标签

XML 复制代码
<!-- id为mapper接口中的方法名字 -->
<select id="selectUserById" parameterType="int" resultType="User">
    SELECT * FROM users WHERE id = #{id}
</select>

3、**<insert>**标签

XML 复制代码
<insert id="insertUser" parameterType="User">
    INSERT INTO users (username, password) VALUES (#{username}, #{password})
</insert>

4、<update> 标签

XML 复制代码
<update id="updateUser" parameterType="User">
    UPDATE users SET username = #{username}, password = #{password} WHERE id = #{id}
</update>

5、**<delete>**标签

XML 复制代码
<delete id="deleteUser" parameterType="int">
    DELETE FROM users WHERE id = #{id}
</delete>

6、**<resultMap>**标签

XML 复制代码
<resultMap id="userResultMap" type="User">
    <id property="id" column="id"/>
    <result property="username" column="username"/>
    <result property="password" column="password"/>
</resultMap>

7、<parameterMap> 标签 (不推荐使用,可以用 <parameterType> 替代)

XML 复制代码
<parameterMap id="userParameterMap" type="User">
    <parameter property="id" jdbcType="INTEGER"/>
</parameterMap>

8、<sql> 标签

XML 复制代码
<sql id="userColumns">
    id, username, password
</sql>

9、<include> 标签

XML 复制代码
<select id="selectUserWithColumns" parameterType="int" resultType="User">
    SELECT <include refid="userColumns"/> FROM users WHERE id = #{id}
</select>

10、 <if> 标签

XML 复制代码
<select id="selectUsersByCriteria" parameterType="Map" resultType="User">
    SELECT * FROM users
    <where>
        <if test="username != null">
            AND username = #{username}
        </if>
        <if test="email != null">
            AND email = #{email}
        </if>
    </where>
</select>

11、**<choose><when><otherwise>**标签

XML 复制代码
<select id="selectUsersByCriteria" parameterType="Map" resultType="User">
    SELECT * FROM users
    <where>
        <choose>
            <when test="username != null">
                AND username = #{username}
            </when>
            <when test="email != null">
                AND email = #{email}
            </when>
            <otherwise>
                <!-- 默认条件 -->
                AND status = '00'
            </otherwise>
        </choose>
    </where>
</select>

12、**<foreach>**标签

XML 复制代码
<select id="selectUsersByIdList" parameterType="List" resultType="User">
    SELECT * FROM users
    WHERE id IN
    <foreach item="id" collection="ids" open="(" separator="," close=")">
        #{id}
    </foreach>
</select>
相关推荐
yuren_xia7 小时前
Spring Boot + MyBatis 集成支付宝支付流程
spring boot·tomcat·mybatis
神仙别闹13 小时前
基于Java(SpringBoot、Mybatis、SpringMvc)+MySQL实现(Web)小二结账系统
java·spring boot·mybatis
crud14 小时前
Spring Boot 整合 MyBatis-Plus:从入门到精通,一文搞定高效持久层开发!
java·spring boot·mybatis
爱上语文14 小时前
MyBatisPlus(3):常用配置
java·后端·mybatis
xlsw_16 小时前
MyBatis之测试添加功能
java·开发语言·mybatis
武子康20 小时前
Java-39 深入浅出 Spring - AOP切面增强 核心概念 通知类型 XML+注解方式 附代码
xml·java·大数据·开发语言·后端·spring
clk66071 天前
SSM 框架核心知识详解(Spring + SpringMVC + MyBatis)
java·spring·mybatis
愿你天黑有灯下雨有伞1 天前
MyBatis-Plus LambdaQuery 高级用法:JSON 路径查询与条件拼接的全场景解析
mysql·json·mybatis
万能的编程语言2 天前
mybatis 参数绑定错误示范(1)
java·mybatis
贺函不是涵2 天前
【沉浸式求职学习day52】【初识Mybaits】
java·学习·mybatis