zoukankan      html  css  js  c++  java
  • MyBatis:传参

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

  • 相关阅读:
    Scala (三)集合
    为什么成为一名程序员?
    Hadoop——Yarn
    Redis(一)NoSQL简介、Redis安装 、数据类型、配置文件、发布订阅
    Java并发编程——共享模型之内存( JMM、原子性、可见性、有序性、volatile原理)
    KafkaAPI实战案例
    分布式技术原理笔记(二)分布式体系结构
    Flume 进阶
    Kafka框架基础
    Scala (二)面向对象
  • 原文地址:https://www.cnblogs.com/fqwsndc1314-5207788/p/7594843.html
Copyright © 2011-2022 走看看