MyBatis从入门到放弃二:传参
2018-06-17 22:42:08来源:未知 阅读 ()
前言
我们在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
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:ASP.NET 运行机制详解
下一篇:linq中给字段添加别名
- 小白如何入门 Python 爬虫? 2019-08-13
- 编程小白的第一本python入门书(高清版)PDF下载 2019-07-24
- 初始Python 2019-07-24
- Python入门学习——PyQt5程序基本结构 2019-07-24
- 经验分享:零基础如何快速入门Python?(菜鸟必看篇) 2019-07-24
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash