飙血推荐
  • HTML教程
  • MySQL教程
  • JavaScript基础教程
  • php入门教程
  • JavaScript正则表达式运用
  • Excel函数教程
  • UEditor使用文档
  • AngularJS教程
  • ThinkPHP5.0教程

Mybatis传多个参数(三种解决方案)

时间:2021-12-15  作者:匿名  

据我目前接触到的传多个参数的方案有三种。

不用 看下面两种了 用这种了。。  好用。。

第三种方案

Dao层的函数方法

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

对应的域名

1 2 3 <select id=" selectUser" resultMap="BaseResultMap">    select  from user_user_t   where user_name = #{userName,jdbcType=VARCHAR} and user_area=#{userArea,jdbcType=VARCHAR} </select

个人觉得这种方法比较好,能让开发者看到dao层方法就知道该传什么样的参数,比较直观,个人推荐用此种方案。

第一种方案

DAO层的函数方法

?
1 Public User selectUser(String name,String area);

对应的域名

?
1 2 3 <select id="selectUser" resultMap="BaseResultMap">     select  from user_user_t   where user_name = #{0} and user_area=#{1} </select>

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

第二种方案

此方法采用Map传多参数.

Dao层的函数方法

?
1 Public User selectUser(Map paramMap);

对应的域名

?
1 2 3 <select id=" selectUser" resultMap="BaseResultMap">    select  from user_user_t   where user_name = #{userName,jdbcType=VARCHAR} and user_area=#{userArea,jdbcType=VARCHAR} </select>

Service层调用

?
1 2 3 4 5 Private User xxxSelectUser(){ Map paramMap=new hashMap(); 域名(“userName”,”对应具体的参数值”); 域名(“userArea”,”对应具体的参数值”); User user=xxx. selectUser(paramMap);}

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

湘ICP备14001474号-3  投诉建议:234161800@qq.com   部分内容来源于网络,如有侵权,请联系删除。