MyBatis传入参数的问题

一、单个参数

  1、基本数据类型

    (1)直接使用    

List tests(long id);
       


    (2)使用注解     
                List tests(@Param("aid") long bid);
      
      #{}中的参数名与方法中的@Param()里的参数名一致

  2、复杂数据类型(这里主要是指Java实体类)
    (1)直接使用   

            List tests(TestQO testQO);
      
      #{}中的参数名与方法中的参数的属性名一致
    (2)使用注解   
           List tests(@Param("atestQO") TestQO btestQO); 
      
      #{}中的参数名与方法中的@Param()里的参数对应的属性名一致,而且必须写成"#{atestQO.id}"的格式,不能简写成"#{id}".
二、多个参数
  1、基本数据类型
    (1)直接使用
      
          List tests(long id,String ruleType); 
      
      这里改用#{index},其中,#{0}代表接收的是dao层中的第一个参数,#{1}代表dao层中第二参数,更多参数一致往后加即可。

    (2)使用注解    

          List tests(@Param("id") long id,@Param("ruleType") String ruleType);
       
      #{}中的参数名与方法中的@Param()里的参数名一致

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

             List tests(@Param("testQO")TestQO testQO,@Param("testQO2")TestQO2 testQO2);
       
      #{}中的参数名与方法中的@Param()里的参数对应的属性名一致,而且必须写成"#{testQO.id}"的格式,不能简写成"#{id}".
  3、基本数据类型与复杂数据类型混合使用
    因为在多参数的情况下,复杂数据类型不能直接使用,所以这里主要尝试基本数据类型直接使用并且复杂数据类型使用注解这一种情况   
          List tests(long id,String ruleType,@Param("testQO2")TestQO2 testQO2);
    

三、List参数 

          List tests(List list); 
  

你可能感兴趣的:(MyBatis传入参数的问题)