MyBatis XML 映射文件中的 SQL 语句可以分为动态语句和静态语句

目录

静态查询:

动态查询:

静态更新:

动态更新:

静态删除:

动态删除:

[动态语句和静态语句在 MyBatis 中的作用如下:](#动态语句和静态语句在 MyBatis 中的作用如下:)


静态查询:

静态查询是指在 SQL 语句中执行固定的查询操作,查询的条件和内容是预先确定的,不会随着用户输入或其他条件的改变而改变。以下是一个静态查询的示例:

XML 复制代码
<select id="selectUsersByRole" resultType="com.example.goods_admin.entity.User">
  SELECT * FROM user
  WHERE name= 'admin'
</select>

在上述的例子中,查询语句中的条件 name= 'admin' 是固定的,无论用户输入什么内容,都会查询出 "name" 字段等于 "admin" 的用户信息。

动态查询:

动态查询是指在 SQL 语句中根据用户输入或其他条件改变查询的操作。查询的条件和内容是根据用户的输入或其他条件动态生成的。以下是一个动态查询的示例:

XML 复制代码
    <select id="seleteUser" resultType="com.example.goods_admin.entity.User">
        select * from user
            <where>
                <if test="keyWord !=null and keyWord!=''">
                    userName like concat('%', #{keyWord}, '%')
                </if>
            </where>

    </select>

在这个示例中,查询语句根据用户输入的关键字来动态生成查询条件。如果用户输入了关键字,那么将会根据userName进行模糊匹配查询。

静态更新:

静态更新是指在 SQL 语句中执行固定的更新操作,更新的内容和条件是预先确定的,不会随着用户输入或其他条件的改变而改变。以下是一个静态更新的示例:

XML 复制代码
<update id="updateUserStatus" parameterType="com.example.goods_admin.entity.User">
  UPDATE user
  SET status = 'active'
  WHERE id = #{id}
</update>

在上述的例子中,更新语句中的条件 id = #{id} 是固定的,无论用户输入什么内容,都会更新 "id" 字段等于给定参数 "id" 的用户状态为 "active"。

动态更新:

动态更新是指在 SQL 语句中根据用户输入或其他条件改变更新的操作。更新的内容和条件是根据用户的输入或其他条件动态生成的。以下是一个动态更新的示例:

XML 复制代码
<update id="updateUser" parameterType="com.example.goods_admin.entity.User">
  UPDATE user
  <set>
    <if test="username != null">
      username = #{username},
    </if>
    <if test="email != null">
      email = #{email},
    </if>
  </set>
  WHERE id = #{id}
</update>

在这个示例中,更新语句根据用户输入的用户名和邮箱来动态生成更新内容,同时根据给定参数 "id" 来确定更新的条件。

静态删除:

静态删除是指在 SQL 语句中执行固定的删除操作,删除的条件是预先确定的,不会随着用户输入或其他条件的改变而改变。以下是一个静态删除的示例:

XML 复制代码
<delete id="deleteUserById" parameterType="java.lang.Integer">
  DELETE FROM user
  WHERE id = #{id}
</delete>

在上述的例子中,删除语句中的条件 id = #{id} 是固定的,无论用户输入什么内容,都会删除 "id" 字段等于给定参数 "id" 的用户。

动态删除:

动态删除是指在 SQL 语句中根据用户输入或其他条件改变删除的操作。删除的条件是根据用户的输入或其他条件动态生成的。以下是一个动态删除的示例:

XML 复制代码
<delete id="deleteUser" parameterType="com.example.goods_admin.entity.User">
  DELETE FROM user
  WHERE 1=1
  <if test="username != null">
    AND username = #{username}
  </if>
  <if test="email != null">
    AND email = #{email}
  </if>
</delete>

在这个示例中,删除语句根据用户输入的用户名和邮箱来动态生成删除条件。

动态语句和静态语句在 MyBatis 中的作用如下:

  1. 静态语句:

    • 静态语句是指在 SQL 语句中执行固定的操作,不会随着用户输入或其他条件的改变而改变。
    • 静态语句适用于那些更新、插入或删除的操作,在这些操作中,更新内容和条件是预先确定的。
    • 静态语句可以通过 MyBatis XML 映射文件来定义,将 SQL 语句与 Java 代码进行分离,提高了代码的可维护性。
    • 静态语句在执行过程中可以利用 MyBatis 的参数映射功能,将 Java 对象的属性值映射到 SQL 语句中的占位符上。
  2. 动态语句:

    • 动态语句是根据用户输入或其他条件改变进行的操作,更新内容和条件是根据动态生成的。
    • 动态语句适用于那些需要根据不同情况执行不同操作的场景,例如根据用户的搜索条件动态生成查询语句。
    • 动态语句可以通过 MyBatis XML 映射文件中的条件判断和循环等标签来实现,根据不同条件动态生成 SQL 语句的不同部分。
    • 动态语句可以使 SQL 语句更加灵活,根据不同的条件在运行时动态生成最终的 SQL 语句,提高了系统的可扩展性和适应性。

总结起来,静态语句适用于固定的操作,而动态语句适用于根据不同条件进行动态生成 SQL 语句的操作。通过使用静态语句和动态语句,可以使数据库操作更加灵活和可维护。

相关推荐
艺杯羹4 小时前
JDBC之ORM思想及SQL注入
数据库·sql·jdbc·orm·sql注入
北极的企鹅886 小时前
XML内容解析成实体类
xml·java·开发语言
北辰浮光7 小时前
[Mybatis-plus]
java·开发语言·mybatis
方圆想当图灵8 小时前
由 Mybatis 源码畅谈软件设计(七):SQL “染色” 拦截器实战
后端·mybatis·代码规范
毅航8 小时前
MyBatis 事务管理:一文掌握Mybatis事务管理核心逻辑
java·后端·mybatis
我的golang之路果然有问题9 小时前
速成GO访问sql,个人笔记
经验分享·笔记·后端·sql·golang·go·database
秃头佛爷10 小时前
常用SQL整理
数据库·sql
浩浩测试一下12 小时前
SQL注入高级绕过手法汇总 重点
数据库·sql·安全·web安全·网络安全·oracle·安全架构
獨枭13 小时前
SQL Server 2019 安装与配置详细教程
sql·sqlserver
啊松同学13 小时前
【Mybatis】MyBatisPlus的saveBatch真的是批量插入吗?深度解析与性能优化
java·后端·性能优化·mybatis