MyBatis从入门到放弃二:传参

2018-06-22 04:39:54来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

前言

      我们在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

 @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 看文档。

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:C#学习笔记-接口与抽象类

下一篇:SqlCommandBuilder类是如何构建T-Sql语句