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

MyBatis:传参的更多相关文章

  1. 问题小记(MyBatis传参出现的小问题)

    问题一:在MyBatis中注解@Param和ParameterType不能一起用,会报错Parameter 'XXX' not found. Available parameters are [1, ...

  2. Mybatis传参方式

    Mybatis传多个参数(三种解决方案) 据我目前接触到的传多个参数的方案有三种. 第一种方案  DAO层的函数方法 ? 1 Public User selectUser(String name,St ...

  3. mybatis传参的几种方式

    1,@Param @参考文章 @Select("select s_id id,s_name name,class_id classid from student where  s_name= ...

  4. Java Mybatis 传参方式

    一.单个参数: public List<XXBean> getXXBeanList(String xxCode); <select id="getXXXBeanList&q ...

  5. mybatis 传参是 list<string> 的注意事项

    <!--付款 批量 修改账单状态--><update id="editbillpayALL" parameterType="java.util.List ...

  6. mybatis传参总结

    注:文章引用部分 mybatis传递参数总结文章内容 一.单个参数 1.基本数据类型 (1)直接使用 List<ChargeRuleDO> tests(long id); <sele ...

  7. mybatis传参问题总结

    一. 传入单个参数 当传入的是单个参数时,方法中的参数名和sql语句中参数名一致即可 List<User> getUser(int id); <select id="get ...

  8. php sql 类似 mybatis 传参

    PHP sql 处理上,没有类似于 java mybatis 的工具,导致进行一些sql 处理时,会有诸多不便, 楼主抽时间写了一个 php 类似 mybatis 的sql 工具,省去了拼装sql 的 ...

  9. Mybatis传参- 被逗号分割的字符串

    String ids = "1,2,3,4,5,6",如ids作为参数传递,查询list返回.mybatis用foreach处理并返回. SELECT * FROM yp_popu ...

  10. mybatis 传参为 Integer 时 ,Mapper 文件 中判断 条件 问题。

    <if test="valiStatus==null || valiStatus=='' || valiStatus==4 "> b.work_permit_card_ ...

随机推荐

  1. DRF跨域,简单请求和复杂请求

    跨域就是跨域名,跨端口 - 为什么会有跨域? 浏览器有同源限制策略 - 绕过浏览器同源策略就可以跨域 -  方式一: jsonp(利用浏览器特性) 在html动态创建script标签 同源策略会阻止a ...

  2. linux gcc nginx

    1.安装GCC[root@rekfan.com opt]# rpm -ivh cpp-4.1.2-48.el5.i386.rpm[root@rekfan.com opt]# rpm -ivh kern ...

  3. 在 Virtual Box 安装 Mac Os 并安装 Qt 开发应用

    导读 由于 Beslyric-for-X 项目开发需要,开始尝试在 Mac Os 下开发 Qt 应用.尝试成功后,记录于此,希望对有类似需求的人有所帮助. 本文以开发 Beslyric-for-X 为 ...

  4. min-max 容斥

    $\min - \max$ 容斥 Part 1 对于简单的$\min - \max$容斥有一般形式,表达为:$\max(S)=\sum\limits_{T\subseteq S}(-1)^{|T|-1 ...

  5. BZOJ 2810 [Apio2012]kunai

    Orz Starria 现在看来,也不是很难,能做...就是不能写 可以想到维护每个苦无扫过的矩形,然后做矩形面积并即可. 然后发现自己只会$n^2$的处理方法... 想了好久之后问了一发 Starr ...

  6. Luogu3702 SDOI2017 序列计数 矩阵DP

    传送门 不考虑质数的条件,可以考虑到一个很明显的$DP:$设$f_{i,j}$表示选$i$个数,和$mod\ p=j$的方案数,显然是可以矩阵优化$DP$的. 而且转移矩阵是循环矩阵,所以可以只用第一 ...

  7. 表单验证(AngularJs)

    这次,学习angularjs的表单的验证,angularjs提供上表几种状态验证: 状态 描述 $invalid 未通过验证 $valid 经过验证 $pristine 未修改过 $dirty 修改 ...

  8. Docker(五):Docker 三剑客之 Docker Machine

    上篇文章Docker(四):Docker 三剑客之 Docker Compose介绍了 Docker Compose,这篇文章我们来了解 Docker Machine . Docker Machine ...

  9. vsftpd虚拟账户配置

    1. 概述 FTP是文件传输协议,在内外网的文件传输中使用广泛. 本篇博客主要介绍FTP服务器的部署和测试. 2. 软件环境部署 查看系统是否安装FTP软件(vsftpd),执行命令:rpm -qa ...

  10. python-编码-15

    ascii A : 00000010 8位 一个字节 unicode A : 00000000 00000001 00000010 00000100 32位 四个字节 中:00000000 00000 ...