一、单个参数

  1、基本数据类型

    (1)直接使用

        select * from t_charge_rule t where t.id = #{aid}
      </select>
      #{}中的参数名与方法中的@Param()里的参数名一致

  2、复杂数据类型(这里主要是指Java实体类)
    (1)直接使用
      List<ChargeRuleDO> tests(TestQO testQO);
      <select >
        select * from t_charge_rule t where t.id = #{0} and t.rule_type=#{1}
      </select>
      这里改用#{index},其中,#{0}代表接收的是dao层中的第一个参数,#{1}代表dao层中第二参数,更多参数一致往后加即可。

    (2)使用注解
      List<ChargeRuleDO> tests(@Param("id") long id,@Param("ruleType") String ruleType);
      <select >
        select * from t_charge_rule t where t.id = #{id} and t.rule_type=#{ruleType}
      </select>
      #{}中的参数名与方法中的@Param()里的参数名一致

  2、复杂数据类型
    (1)直接使用
      尝试了两种取参数的方法都不行

    (2)使用注解
      List<ChargeRuleDO> tests(@Param("testQO")TestQO testQO,@Param("testQO2")TestQO2 testQO2);
      <select >
      select * from t_charge_rule t where t.id = #{0} and t.rule_type=#{1} and t.user_id=#{testQO2.uesrId}
    </select>

三、List参数
  List<ChargeRuleDO> tests(List<long> list);
  <select >
        #{item}
      </foreach>
  </select>

 

  以上是我遇到过的,并且曾经犯过错误的几种方式.当然还有别的一些传参方式,在这里我就不一一写出来了,大家可以自己去百度,等遇到了,我再补充.

相关文章:

  • 2021-06-26
  • 2022-12-23
  • 2022-12-23
  • 2021-07-19
  • 2022-01-01
  • 2022-12-23
  • 2021-07-24
猜你喜欢
  • 2021-06-25
  • 2021-09-26
  • 2022-02-23
  • 2022-01-17
相关资源
相似解决方案