当前位置:   article > 正文

MyBatis常用的XML标签

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> 标签 

  1. <!-- userMapper.xml -->
  2. <mapper namespace="com.example.UserMapper">
  3. <!-- SQL语句和其他标签在这里定义 -->
  4. </mapper>

  2、<select> 标签

  1. <!-- id为mapper接口中的方法名字 -->
  2. <select id="selectUserById" parameterType="int" resultType="User">
  3. SELECT * FROM users WHERE id = #{id}
  4. </select>

  3、<insert> 标签 

  1. <insert id="insertUser" parameterType="User">
  2. INSERT INTO users (username, password) VALUES (#{username}, #{password})
  3. </insert>

  4、<update> 标签 

  1. <update id="updateUser" parameterType="User">
  2. UPDATE users SET username = #{username}, password = #{password} WHERE id = #{id}
  3. </update>

  5、<delete> 标签 

  1. <delete id="deleteUser" parameterType="int">
  2. DELETE FROM users WHERE id = #{id}
  3. </delete>

  6、<resultMap> 标签 

  1. <resultMap id="userResultMap" type="User">
  2. <id property="id" column="id"/>
  3. <result property="username" column="username"/>
  4. <result property="password" column="password"/>
  5. </resultMap>

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

  1. <parameterMap id="userParameterMap" type="User">
  2. <parameter property="id" jdbcType="INTEGER"/>
  3. </parameterMap>

  8、<sql> 标签 

  1. <sql id="userColumns">
  2. id, username, password
  3. </sql>

  9、<include> 标签 

  1. <select id="selectUserWithColumns" parameterType="int" resultType="User">
  2. SELECT <include refid="userColumns"/> FROM users WHERE id = #{id}
  3. </select>

  10、 <if> 标签 

  1. <select id="selectUsersByCriteria" parameterType="Map" resultType="User">
  2. SELECT * FROM users
  3. <where>
  4. <if test="username != null">
  5. AND username = #{username}
  6. </if>
  7. <if test="email != null">
  8. AND email = #{email}
  9. </if>
  10. </where>
  11. </select>

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

  1. <select id="selectUsersByCriteria" parameterType="Map" resultType="User">
  2. SELECT * FROM users
  3. <where>
  4. <choose>
  5. <when test="username != null">
  6. AND username = #{username}
  7. </when>
  8. <when test="email != null">
  9. AND email = #{email}
  10. </when>
  11. <otherwise>
  12. <!-- 默认条件 -->
  13. AND status = '00'
  14. </otherwise>
  15. </choose>
  16. </where>
  17. </select>

  12、<foreach> 标签

  1. <select id="selectUsersByIdList" parameterType="List" resultType="User">
  2. SELECT * FROM users
  3. WHERE id IN
  4. <foreach item="id" collection="ids" open="(" separator="," close=")">
  5. #{id}
  6. </foreach>
  7. </select>
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/码创造者/article/detail/948078
推荐阅读
相关标签
  

闽ICP备14008679号