MyBatis多属性查询的三种方式

接口方法定义

   List<Player> findPlayer1(Map<String, Object> queryMap);
   List<Player> findPlayer3(PlayerQueryBean playerQueryBean);
   List<Player> findPlayer2(@Param("team") String team, @Param("height") Float height);

一、注解的方式

   // 第二种方式直接使用参数
   String team = "Laker";
   Float height = 1.98F;
   List<Player> list2 = mapper.findPlayer2(team, height);
   System.out.println(list2);
   
    Mapper文件:
    <select id="findPlayer2" resultType="Player">
            select  *
            from tb_player a
            where a.team = #{team} and
            a.height = #{height}
        </select>

二、Map的方式

    // 第一种方式使用map
    String team = "Laker";
    Float height = 1.98F;
    Map<String, Object> params = new HashMap<String, Object>();
    params.put("team", team);
    params.put("height", height);
    List<Player> list1 = mapper.findPlayer1(params);
    System.out.println(list1);
    
    
    Mapper文件:
    <select id="findPlayer1" resultType="Player"
                parameterType="map">
            select *
            from tb_player a
            where a.team = #{team} and
            a.height = #{height}
        </select>

三、Bean的方式

     // 第三种方式用对象
     String team = "Laker";
    Float height = 1.98F;
    PlayerQueryBean playerQueryBean = new PlayerQueryBean();
    playerQueryBean.setTeam(team);
    playerQueryBean.setHeight(height);
    List<Player> list3 = mapper.findPlayer3(playerQueryBean);
    System.out.println(list3);
    
    Mapper文件:
    <select id="findPlayer3" resultType="Player"
          parameterType="com.intellif.mozping.querybean.PlayerQueryBean">
        select  *
        from tb_player a
        where a.team = #{team} and
        a.height = #{height}
    </select>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值