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>
相关推荐
微笑伴你而行3 小时前
目标检测如何将同时有方形框和旋转框的json/xml标注转为txt格式
xml·目标检测·json
javadaydayup7 小时前
为什么 MyBatis Mapper 接口能像普通 Bean 一样被 @Autowired?
后端·mybatis
fatiaozhang95278 小时前
数码视讯TR100-OTT-G1_国科GK6323_安卓9_广东联通原机修改-TTL烧录包-可救砖
android·xml·电视盒子·刷机固件·机顶盒刷机
l1t9 小时前
美团龙猫利用expat库实现的保存xml指定范围数据到csv的C程序
xml·c语言·解析器·expat
小趴菜不能喝1 天前
Spring boot3.x整合mybatis-plus踩坑记录
java·spring boot·mybatis
焯7591 天前
若依微服务遇到的配置问题
java·mybatis·ruoyi
l1t2 天前
DuckDB新版rusty_sheet 插件测试
xml·数据库·rust·插件·xlsx·duckdb
颜如玉2 天前
MybatisPlus Sql Inject魔法🪄
后端·mybatis·源码
叫我阿柒啊2 天前
从全栈开发到微服务架构:一位Java工程师的实战经验分享
java·ci/cd·kafka·mybatis·vue3·springboot·fullstack
l1t2 天前
美团龙猫(longcat.AI)编写的利用二分查找优化Excel的sheet.xml指定范围输出C程序
xml·c语言·excel·解析器