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 看文档。
MyBatis:传参的更多相关文章
- 问题小记(MyBatis传参出现的小问题)
问题一:在MyBatis中注解@Param和ParameterType不能一起用,会报错Parameter 'XXX' not found. Available parameters are [1, ...
- Mybatis传参方式
Mybatis传多个参数(三种解决方案) 据我目前接触到的传多个参数的方案有三种. 第一种方案 DAO层的函数方法 ? 1 Public User selectUser(String name,St ...
- mybatis传参的几种方式
1,@Param @参考文章 @Select("select s_id id,s_name name,class_id classid from student where s_name= ...
- Java Mybatis 传参方式
一.单个参数: public List<XXBean> getXXBeanList(String xxCode); <select id="getXXXBeanList&q ...
- mybatis 传参是 list<string> 的注意事项
<!--付款 批量 修改账单状态--><update id="editbillpayALL" parameterType="java.util.List ...
- mybatis传参总结
注:文章引用部分 mybatis传递参数总结文章内容 一.单个参数 1.基本数据类型 (1)直接使用 List<ChargeRuleDO> tests(long id); <sele ...
- mybatis传参问题总结
一. 传入单个参数 当传入的是单个参数时,方法中的参数名和sql语句中参数名一致即可 List<User> getUser(int id); <select id="get ...
- php sql 类似 mybatis 传参
PHP sql 处理上,没有类似于 java mybatis 的工具,导致进行一些sql 处理时,会有诸多不便, 楼主抽时间写了一个 php 类似 mybatis 的sql 工具,省去了拼装sql 的 ...
- Mybatis传参- 被逗号分割的字符串
String ids = "1,2,3,4,5,6",如ids作为参数传递,查询list返回.mybatis用foreach处理并返回. SELECT * FROM yp_popu ...
- mybatis 传参为 Integer 时 ,Mapper 文件 中判断 条件 问题。
<if test="valiStatus==null || valiStatus=='' || valiStatus==4 "> b.work_permit_card_ ...
随机推荐
- mysql 数据库表备份和还原
#!/bin/bash #ip地址 HOST=localhost #用户名 USER=claim #密码 PASSWORD=Pw123456! #数据库名称 DATABASE=claim_oauth2 ...
- MySQL 基础六 临时表 复制表结构
1.临时表CREATE TEMPORARY TABLE test2( id INT ) SELECT *FROM test2 SHOW TABLES; INSERT INTO test2 VALUES ...
- Mybatis学习总结(二)——Mapper代理开发
一.概要 1.原始DAO开发中存在的问题:(1)DAO实现方法体中存在很多过程性代码.(2)调用SqlSession的方法(select/insert/update)需要指定Statement的id, ...
- 如何利用Skyline的TerraExplorer Pro 6.5提供的API接口实现矢量图层数据的动态投影
Skyline 支持国内常见的地图投影坐标系,包括WGS84.Beijing54.西安80.2000坐标系等,也可以自定义坐标系,比如一些做过参数变换加密的坐标系等. <!DOCTYPE htm ...
- 虚拟机vbox
https://www.virtualbox.org/wiki/Linux_Downloads 一直在报内核出错的问题,我尝试了各种方法还是无果,猜测是版本的问题,这里推荐各位安装virtualbox ...
- ASP.NET Core中获取完整的URL(转载)
在之前的ASP.NET中,可以通过 Request.Url.AbsoluteUri 获取,但在ASP.NET Core没有这个实现,请问如何获取呢?方法一:先引用“using Microsoft.As ...
- linux驱动编写之阻塞与非阻塞
一.概念 应用程序使用API接口,如open.read等来最终操作驱动,有两种结果--成功和失败.成功,很好处理,直接返回想要的结果:但是,失败,是继续等待,还是返回失败类型呢? 如果继续等待,将进 ...
- Android开发——ListView使用技巧总结(一)
)还有一点就是要控制异步任务的执行频率,因为当用户频繁的上下滑动,会瞬间产生上百个异步任务,会带来无意义的大量的UI更新操作,因此可以考虑在列表滑动时停止进行异步任务,直到列表停下来. //判断列表的 ...
- java 基础02 打包package
- 使用 cron 定时任务实现 war 自动化发布
autoRelease.sh #!/bin/sh /home/tomcat/bin/shutdown.sh echo "tomcat stoped" cd /home/tomcat ...