mybatis(4)输入映射

通过parameterType指定输入参数的类型,类型可以是简单类型、hashmappojo的包装类型。

1.1 传递pojo的包装对象

1.1.1 需求

完成用户信息的综合查询,需要传入查询条件很复杂(可能包括用户信息、其它信息,比如商品、订单的)

1.1.2 定义包装类型pojo

针对上边需求,建议使用自定义的包装类型的pojo在包装类型的pojo中将复杂的查询条件包装进去。

package com.xdy.mybatis.po;

public class UserQueryVo {
	
	//用户查询条件
	private UserCustom userCustom;

	public UserCustom getUserCustom() {
		return userCustom;
	}

	public void setUserCustom(UserCustom userCustom) {
		this.userCustom = userCustom;
	}
	
	
}

1.1.3 mapper.xml

<!-- 用户信息综合查询 -->
	<select id="findUserList" parameterType="com.xdy.mybatis.po.UserQueryVo"
		resultType="com.xdy.mybatis.po.UserCustom">
		SELECT * FROM USER WHERE `user`.sex=#{userCustom.sex} and `user`.username like '%${userCustom.username}%'
	</select>

1.1.4 mapper.java

public List<UserCustom> findUserList(UserQueryVo userQueryVo) throws Exception;

1.1.5 测试代码

@Test
	public void testFindUserList() throws Exception {
		SqlSession sqlSession = sqlSessionFactory.openSession();
		UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
		
		UserQueryVo userQueryVo = new UserQueryVo();
		UserCustom userCustom = new UserCustom();
		userCustom.setSex("1");
		userCustom.setUsername("小明");
		userQueryVo.setUserCustom(userCustom);
		
		List<UserCustom> list = userMapper.findUserList(userQueryVo);
		System.out.println(list);
		sqlSession.close();
	}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值