MyBatis:传参

本文介绍在MyBatis中如何使用Map传递多个参数到SQL语句,并通过RowBounds实现简单的分页功能。

MyBatis从入门到放弃二:传参

前言

      我们在mapper.xml写sql,如果都是一个参数,则直接配置parameterType,那实际业务开发过程中多个参数如何处理呢?

      从MyBatis API中发现selectOne和selectLit方法重载第一个传statement,第二个传Object。那么我们则用Map来传多个参数。

 

准备工作

      开发环境、pom.xml、mapper.xml、log4j.properties同上文。

 

mapper.xml SQL实现

<select id="queryUserByAddress" resultType="com.autohome.model.User"> select * from t_userinfo where name=#{name,javaType=String,jdbcType=VARCHAR} and address=#{address} </select>

 

单元测试

   创建Map传参,map的key值和mapper sql参数名称相对应。

复制代码
@Test
    public void queryUserByNameAddress(){
        SqlSession sqlSession=null;
        try{
            sqlSession=sqlSessionFactory.openSession();
            Map<String,Object> map =new HashMap<String,Object>(); map.put("name","kobe"); map.put("address","usa"); User user = sqlSession.selectOne("com.autohome.mapper.User.queryUserByAddress",map); System.out.println("id:"+user.getId()+",name:"+user.getName()+","+user.getAddress()); }catch(Exception e){ e.printStackTrace(); }finally { sqlSession.close(); } }
复制代码

 

使用RowBounds实现分页

    在看mybatis API时发现了rowbounds参数,可以用来实现分页,不过他并不是直接在sql中实现,只是在查询结果集的基础上实现数据分页,小数量可用,大数据量则不推荐,也权当是做个demo

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
@Test
   public void queryPagedUsers(){
        
       SqlSession sqlSession=null;
 
       try {
 
           sqlSession=sqlSessionFactory.openSession();
           RowBounds row=new  RowBounds(10, 10);
           List<User> list = sqlSession.selectList("com.autohome.mapper.User.queryUsers",null,row);
           System.out.println("size:"+list.size());
           for (User user:list){
               System.out.println("id:"+user.getId()+",name:"+user.getName()+","+user.getAddress());
           }
       } catch (Exception e) {
           e.printStackTrace();
       }finally {
           sqlSession.close();
       }
   }

 附DEBUG截图

 

总结

     起初学习java时总是不知从何学起,总算是在跌跌撞撞中入了门,我自己总结为学习java没什么捷径可言,唯能做的就是敲demo 看文档、敲demo 看文档、敲demo 看文档。

转载于:https://www.cnblogs.com/fqwsndc1314-5207788/p/7594843.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值