MyBatis学习之传递多个参数(一)

MyBatis版本: 3.4.0+

<resultMap type="com.kinsey.woo.Dto.Role" id="roleResultMap">
 		<id column="id" property="id"/>
 		<result column="role_name" property="roleName"/>
 		<result column="note" property="note"/>
 	</resultMap>


(1)通过Map传递参数

    <select id="findRoleByMap" parameterType="map" resultMap="roleMap">
    	select id,role_name,note 
    	  from t_role
    	  where role_name like concat('%',#{roleName},'%')
    		     and note like concat('%',#{note},'%')
    </select>

接口: 

public List<Role> findRoleByMap(HashMap<String,String> params);


优缺点:简单易用,传递Map业务性不强,需要输入代码程序中才能看到具体传递什么参数。


(2)使用注解方式

  //使用注解方式
    public List<Role> findRoleByAnnotation(
    		@Param("roleName") String rolename, @Param("note") String note);


Param为org.apache.ibatis.annotations.Param

 <select id="findRoleByAnnotation" resultMap="roleMap">
    	select id,role_name,note 
    	  from t_role
    	  where role_name like concat('%',#{roleName},'%')
    		     and note like concat('%',#{note},'%')
    </select>

优缺点: 一目了然,但是参数过多,可读性极差


(2)JavaBean传递参数

RoleParam.java

public class RoleParam {
	
	private String roleName;
	
	private String note;

	public String getRoleName() {
		return roleName;
	}

	public void setRoleName(String roleName) {
		this.roleName = roleName;
	}

	public String getNote() {
		return note;
	}

	public void setNote(String note) {
		this.note = note;
	}

}

//使用JavaBean传递参数
    public List<Role> findRoleByParams(RoleParam roleParam);

    <select id="findRoleByParam" parameterType="Open Declaration com.kinsey.woo.Dto.RoleParam
" resultMap="roleMap">
    	select id,role_name,note 
    	  from t_role
    	  where role_name like concat('%',#{roleName},'%')
    		     and note like concat('%',#{note},'%')
    </select>

总结:

(1)使用Map传递参数。可读性差,后续维护与扩展差

(2)@Param注解方式,受参数个数影响,<=5个参数为佳,超过推荐使用JavaBean方式

(3)当参数个数超过5个时,请使用JavaBean方式









评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值