IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> mybatis的学习4(动态sql:where、choose、trim、foreach的应用) -> 正文阅读

[大数据]mybatis的学习4(动态sql:where、choose、trim、foreach的应用)

关于mybatis的动态SQL官网网址点击跳转
动态SQL其实就是你可以加上自定义的条件,从而更好的获取到需要的数据。
这是映射文件的结果集映射,后面都要用的

<resultMap id="admin" type="com.csh.bean.Admin">
        <id property="adminAccount" column="admin_account"></id>
        <result property="adminPwd" column="admin_pwd"></result>
    </resultMap>

dao层中的方法

public interface AdminDao {
    public List<Admin> selectAll(Admin admin);
    public List<Admin> selectAll2(Admin admin);
    public List<Admin> selectAll3(Admin admin);
    public List<Admin> selectAdminByAccount(@Param("adminAccounts") List<String> adminAccounts);
}

1、where:与sql语句中的where使用一样,这里为标签显示,同样会在SQL语句上显示where,一般可与if标签一起使用,直接看例子吧

<select id="selectAll" resultMap="admin">
        select * from admin
        <where>
            <if test="adminPwd != null">
                admin_pwd  = #{adminPwd}
            </if>
            <if test="adminAccount != null">
                and admin_account = #{adminAccount}
            </if>
        </where>
    </select>

其实跟其他语言一样,只是加上if作为判断语句,而sql语句的条件限制一般都在where后面

2、choose
choose标签里有whenotherwise标签

<select id="selectAll2" resultMap="admin">
        select * from admin
        <where>
            <choose>
                <when test="adminAccount != null">
                    admin_account = #{adminAccount}
                </when>
                <when test="adminPwd != null">
                    admin_pwd = #{adminPwd}
                </when>
                <otherwise >
                    1 = 1
                </otherwise>
            </choose>
        </where>
    </select>

这里的choose里边有两个when、一个otherwise,执行效果与java中的if...else if...if...效果是一样的

3、trim
trim是可以自定义where语句
prefix:为sql语句整体增加一个前缀
prefixOverrides:去除整体sql语句前面多余的字符串
suffixOverrides:去除整体sql语句后面多余的字符串
suffix:为sql语句整体增加一个后缀

<select id="selectAll3" resultMap="admin">
        select * from admin
        <where>
            <trim prefixOverrides="and" suffixOverrides="and">
                <if test="adminPwd != null">
                    admin_pwd  = #{adminPwd} and
                </if>
                <if test="adminAccount != null">
                    and admin_account = #{adminAccount} and
                </if>
            </trim>
        </where>
    </select>

匹配多个时,中间加"|",如suffixOverrides="and | or"

4、foreach:遍历集合中的元素
标签中元素
collection:指定要遍历的集合
separator:分隔符
open:以什么开始
close:以什么结束
item:遍历过程中的每一个元素值
index:表示索引

<select id="selectAdminByAccount" resultMap="admin">
        select * from admin where admin_account in
        <foreach collection="adminAccounts" close=")" index="" item="account" open="(" separator=",">
            #{account}
        </foreach>
    </select>

上面几个是常用的,还有
script:在带注解的映射器接口类中使用动态 SQL,可以使用 script 元素

 @Update({"<script>",
      "update Author",
      "  <set>",
      "    <if test='username != null'>username=#{username},</if>",
      "    <if test='password != null'>password=#{password},</if>",
      "    <if test='email != null'>email=#{email},</if>",
      "    <if test='bio != null'>bio=#{bio}</if>",
      "  </set>",
      "where id=#{id}",
      "</script>"})
    void updateAuthorValues(Author author);

还有bind多数据库支持动态SQL中插入脚本语言看官网详解吧

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-21 20:57:41  更:2022-03-21 21:00:03 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 18:01:43-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码