zoukankan      html  css  js  c++  java
  • Mybatis传递多个参数

    方案一:

    DAO层的函数方法

    User selectUser(String name,String area);

    对应的Mapper.xml

    <selectid="selectUser"resultMap="BaseResultMap">
        select  *  from user_user_t   
        where user_name = #{0} and user_area=#{1}
    </select>

    其中,#{0}代表接收的是dao层中的第一个参数,#{1}代表dao层中第二参数,更多参数一致往后加即可。

    方案二:

    此方法采用Map传多参数. Dao层的函数方法

    User selectUser(Map paramMap);

    对应的Mapper.xml

    <selectid=" selectUser"resultMap="BaseResultMap">
       select  *  fromuser_user_t 
       where user_name = #{userName,jdbcType=VARCHAR} 
            and user_area=#{userArea,jdbcType=VARCHAR}
    </select>

    Service层调用

    Private UserxxxSelectUser(){
        Map paramMap=new hashMap();
        paramMap.put(“userName”,”对应具体的参数值”);
        paramMap.put(“userArea”,”对应具体的参数值”);
        Useruser=xxx. selectUser(paramMap);
    }

    个人认为此方法不够直观,见到接口方法不能直接的知道要传的参数是什么。

    方案三:(推荐)

    Dao层的函数方法

    User selectUser(@param(“userName”)Stringname,@param(“userArea”)String area);

    对应的Mapper.xml

    <selectid=" selectUser"resultMap="BaseResultMap">
       select  *  from user_user_t 
       where user_name = #{userName,jdbcType=VARCHAR} 
            and user_area=#{userArea,jdbcType=VARCHAR}
    </select>
  • 相关阅读:
    暑假集训Day14 I (莫队)
    暑假集训Day14 G (gcd 数学)
    暑假集训Day13 H (进制转换 数学)
    暑假集训Day13 C (二分+贪心)
    暑假集训Day13 I (区间DP)
    暑假集训Day12 H (数论 STL)
    Java8中list转map方法总结
    Typora ---一款简洁的Markdown编辑器
    java8 map flatmap
    Elasticsearch基本查询总结
  • 原文地址:https://www.cnblogs.com/wslook/p/9185506.html
Copyright © 2011-2022 走看看