Day03 Mybatis学习(2) 动态SQL

Day03 Mybatis学习(2) 动态SQL

Mybatis 的映射文件中,前面我们的 SQL 都是比较简单的,有些时候业务逻辑复杂时,我们的 SQL 是动态变 化的,此时在前面的学习中我们的 SQL 就不能满足要求了

一、动态 SQL 之if 标签

我们根据实体类的不同取值,使用不同的 SQL 语句来进行查询。比如在 id 如果不为空时可以根据 id 查询, 如果 username 不同空时还要加入用户名作为条件。这种情况在我们的多条件组合查询中经常会碰到

1.持久层dao接口

    //根据传入的参数条件查询
    List<User> findUserByCondition(User user);

2、持久层 Dao 映射配置

<!--根据条件查询-->
    <select id="findUserByCondition" resultMap="userMap" parameterType="user">
        select * from user where 1=1
        <if test="userName != null">
        and username=#{userName}
        </if>

        <if test="userSex != null">
        and sex=#{userSex}
        </if>
    </select>

3、测试类

    @Test
    public void testFindUserByCondition() {
        User u = new User();
        u.setUserName("老王");
        u.setAddress("北京");
        List<User> users = iUserDao.findUserByCondition(u);
        for (User user : users) {
            System.out.println(user);
        }
    }

二、动态 SQL 之标签

为了简化上面 where 1=1 的条件拼装,我们可以采用标签来简化开发。

1.持久层 Dao 映射配置

<select id="findUserByCondition" resultMap="userMap" parameterType="user">
        select * from user
        <where>
            <if test="userName != null">
                and username=#{userName}
            </if>

            <if test="userSex != null">
                and sex=#{userSex}
            </if>
        </where>
    </select>

2.测试类

public void testFindUserByCondition() {
        User u = new User();
        u.setUserName("老王");
        u.setUserSex("女");
        List<User> users = iUserDao.findUserByCondition(u);
        for (User user : users) {
            System.out.println(user);
        }
    }

运行结果:
在这里插入图片描述

三、动态标签之foreach标签

传入多个 id 查询用户信息,用下边两个 sql 实现:
SELECT * FROM USERS WHERE username LIKE ‘%张%’ AND (id =10 OR id =89 OR id=16) SELECT * FROM USERS WHERE username LIKE ‘%张%’ AND id IN (10,89,16)

这样我们在进行范围查询时,就要将一个集合中的值,作为参数动态添加进来。

1.在 QueryVo 中加入一个 List 集合用于封装参数

在这里插入图片描述

2.持久层 Dao 接口 IUserDao

 //根据QueryVo中提供的id集合 查询用户信息
    List<User> findUserInIds(QueryVo vo);

3.持久层 Dao 映射配置

<!--根据QueryVo中的id集合实现查询用户列表-->
    <select id="findUserInIds" resultMap="userMap" parameterType="queryvo">
        select * from user
        <where>
            <if test="ids != null and ids.size()>0">
                <foreach collection="ids" open="and id in (" close=")" item="id" separator=",">
                    #{id}
                </foreach>

            </if>
        </where>
    </select>

4.测试类

@Test
    public void testfindUserInIds(){
        QueryVo vo = new QueryVo();
        List<Integer> list = new ArrayList<Integer>();
        list.add(46);
        list.add(48);
        vo.setIds(list);
        List<User> users = iUserDao.findUserInIds(vo);
        for (User user : users) {
            System.out.println(user);
        }
    }

运行结果:

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值