关闭

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

13532人阅读 评论(2) 收藏 举报
分类:

Mybatis的Mapper接口的参数,一般是一个对象,但如果不是对象,并且有多个参数的时候呢?我们第一个的想法是把参数封装成一个java.util.Map类型,然后在方法的注释上面写上map的key是什么,但是,这样的做法明显不够直观,不能够一眼看出这个方法的参数是什么,并且,影响到了java方法的多态性(方法名相同,参数数量或类型不同)。下面的方法一和方法二能够解决问题!

一、DAO层的函数方法

Public UserselectUser(String name,String area);

对应的Mapper.xml

<select id="selectUser"resultMap="BaseResultMap">
    select *  fromuser_user_t   whereuser_name = #{0} anduser_area=#{1}
</select>

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

二、此方法采用Map传多参数.

Dao层的函数方法

PublicUser selectUser(Map paramMap);

对应的Mapper.xml

<select id=" selectUser" resultMap="BaseResultMap">
   select *  fromuser_user_t   whereuser_name = #{userName,jdbcType=VARCHAR}anduser_area=#{userArea,jdbcType=VARCHAR}
</select>

Service层调用

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


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

三、Dao层的函数方法

Public User selectUser(@Param(“userName”)String name,@Param(“userArea”)String area);

对应的Mapper.xml

<select id=" selectUser" resultMap="BaseResultMap">
   select *  fromuser_user_t   whereuser_name = #{userName,jdbcType=VARCHAR}anduser_area=#{userArea,jdbcType=VARCHAR}
</select> 
个人觉得这种方法比较好,能让开发者看到dao层方法就知道该传什么样的参数,比较直观,个人推荐用此种方案。
1
0
查看评论

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

第一种方案  DAO层的函数方法  Public User selectUser(String name,String area);    对应的Mapper.xml select * from user_user_t where ...
  • guicaizhou
  • guicaizhou
  • 2016-10-18 16:30
  • 5278

Mybatis传多个参数(三种解决方案) mapper.xml的sql语句修改!

第一种方案  DAO层的函数方法  ? 1 Public User selectUser(String name,String area); 对应的Mapper.xml...
  • u013547551
  • u013547551
  • 2017-08-09 12:25
  • 2566

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

Mybatis的Mapper接口的参数,一般是一个对象,但如果不是对象,并且有多个参数的时候呢?我们第一个的想法是把参数封装成一个java.util.Map类型,然后在方法的注释上面写上map的key是什么,但是,这样的做法明显不够直观,不能够一眼看出这个方法的参数是什么,并且,影响到了java方法...
  • liangyihuai
  • liangyihuai
  • 2015-11-21 16:59
  • 13532

MyBatis查询多个参数传入的问题

一、单个参数: public List getCarEventList(String eventCode);     select t.* from car_event t where t.id= #{id}     其中方法名和ID一...
  • learner198461
  • learner198461
  • 2017-03-02 11:27
  • 438

Mybatis传入多个参数和${}与#{}的区别

一、单个参数: public ListXXBean> getXXBeanList(String xxCode); select id="getXXXBeanList" parameterType="java.lang.String" re...
  • drdongshiye
  • drdongshiye
  • 2017-10-24 17:38
  • 221

MyBatis传入多个参数

MyBatis传入多个参数
  • qq_15266291
  • qq_15266291
  • 2017-02-07 21:41
  • 1406

MyBatis之传入参数

在MyBatis的select、insert、update、delete这些元素中都提到了parameterType这个属性。MyBatis现在可以使用的parameterType有基本数据类型和JAVA复杂数据类型 基本数据类型:包含int,String,Date等。基本
  • liaoxiaohua1981
  • liaoxiaohua1981
  • 2011-10-11 14:40
  • 140992

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

Mybatis传多个参数(三种解决方案)
  • u011647962
  • u011647962
  • 2016-07-26 03:08
  • 5077

mybatis中association的column传入多个参数值

顾名思义,association是联合查询。 在使用association中一定要注意几个问题。文笔不好,白话文描述一下。 1: fncg_PD_QRY_MANAGE 是哪来的?看红色部分, public class FNCG_PD_QRY extends BasePO{ privat...
  • happyrabbit456
  • happyrabbit456
  • 2016-03-04 21:08
  • 2667

MyBatis多参数传递的四种方式

一、多参数传递之注解方式示例 若映射器中的方法只有一个参数,则在对应的SQL语句中,可以采用#{参数名}的方式来引用此参数,以前的例子多属于此类。但这种方法却不适用于需要传递多个参数的情况,今天就来介绍如何使用注解传递多个参数。 1、使用注解实现多参数传递     &#...
  • Victor_Cindy1
  • Victor_Cindy1
  • 2015-12-06 16:06
  • 6428
    个人资料
    • 访问:199618次
    • 积分:3167
    • 等级:
    • 排名:第12861名
    • 原创:137篇
    • 转载:40篇
    • 译文:2篇
    • 评论:31条
    博客专栏
    最新评论