咱们在mapper.xml写sql,若是都是一个参数,则直接配置parameterType,那实际业务开发过程当中多个参数如何处理呢?html
从MyBatis API中发现selectOne和selectLit方法重载第一个传statement,第二个传Object。那么咱们则用Map来传多个参数。java
开发环境、pom.xml、mapper.xml、log4j.properties同上文。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参数名称相对应。mybatis
@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(); } }
在看mybatis API时发现了rowbounds参数,能够用来实现分页,不过他并非直接在sql中实现,只是在查询结果集的基础上实现数据分页,小数量可用,大数据量则不推荐,也权当是作个demoapp
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截图post
起初学习java时老是不知从何学起,总算是在跌跌撞撞中入了门,我本身总结为学习java没什么捷径可言,惟能作的就是敲demo 看文档、敲demo 看文档、敲demo 看文档。单元测试