Mybatis 学习笔记 (五)---- 参数处理

本贴最后更新于 1955 天前,其中的信息可能已经物是人非

1.在用#{}取值时,可能会遇到两种情况:
1)单参数:mybatis 不会做特殊处理, #{参数名/任意名}:取出参数值。
2)多个参数:mybatis 会做特殊处理。多个参数会被封装成 一个 map,
其中 key:param1...paramN,或者参数的索引也可以
  value:传入的参数值
  #{}就是从 map 中获取指定的 key 的值;
例子:
在 EmployeeMapper.java 中,当方法为:public Employee getEmpByIdAndLastName(Integer id,String lastName);
在 EmployeeMapping.xml 中

  <select id="getEmpByidAndLastName" resultType="com.Mybatis.entity.Employee">
  	select * from mybatis_employee where id=#{id} and Last_Name=#{Last_Name}
	/*取值用:#{id},#{lastName}*/
  </select>

在 Mybatis_Test.java 中

	@Test
	public void Test3() throws IOException {
		// 1.获得SqlSessionFactory
		SqlSessionFactory sessionFactory = getSessionFactory();
		// 2.获得SqlSession
		SqlSession openSession = sessionFactory.openSession(true);
		// 3.获取接口类对象
		try {
			EmployeeMapper mapper = openSession.getMapper(EmployeeMapper.class);
			 Employee employee = mapper.getEmpByidAndLastName(9, "xiaowen");
			 System.out.println(employee);
		} finally {
			openSession.close();
		}

	}

发现会出现异常,无法正常输出,异常提示为:
imagepng
导致出现这样结果的原因是什么呢?
之前在前面说了,多个参数的话会被封装成一个 map
这个时候 如果要获得正常结果的话,我们可以采用如下方法
a)直接在 EmployeeMapper.java 中,方法修改为:public Employee getEmpByIdAndLastName(@Param("id")Integer id,@Param("Last_Name")String lastName);
就是在方法参数前面自定义命名,这样就可以正常输出了.
b)在 EmployeeMapping.xml 中 修改#{}中的参数为 Param1....Param N

  <select id="getEmpByidAndLastName" resultType="com.Mybatis.entity.Employee">
  	select * from mybatis_employee where id=#{param1} and Last_Name=#{param2}
  </select>

c)Map:如果多个参数不是业务模型中的数据,没有对应的 pojo,不经常使用,为了方便,我们也可以传入 map
`EmployeeMapper.java 中 定义 public Employee getEmpByMap(Map<String,Object> map);'
EmployeeMapping.xml

  </select>
    <select id="getEmpByMap" resultType="com.Mybatis.entity.Employee">
  	select * from mybatis_employee where id=#{id} and Last_Name=#{lastname}
  </select>

Mybatis_Test.java 中

	@Test
	public void Test4() throws IOException {
		// 1.获得SqlSessionFactory
		SqlSessionFactory sessionFactory = getSessionFactory();
		// 2.获得SqlSession
		SqlSession openSession = sessionFactory.openSession(true);
		// 3.获取接口类对象
		try {
			EmployeeMapper mapper = openSession.getMapper(EmployeeMapper.class);
			Map<String,Object> map = new HashMap<>();
			map.put("id",1);
			map.put("lastname", "xiaoming");
			Employee empByMap = mapper.getEmpByMap(map);
			System.out.println(empByMap);
		} finally {
			openSession.close();
		}

========================思考================================
public Employee getEmp(@Param("id")Integer id,String lastName);
取值:id==>#{id/param1} lastName==>#{param2}

public Employee getEmp(Integer id,@Param("e")Employee emp);
取值:id==>#{param1} lastName===>#{param2.lastName/e.lastName}

特别注意:如果是 Collection(List、Set)类型或者是数组,也会特殊处理。也是把传入的 list 或者数组封装在 map 中。
key:Collection(collection),如果是 List 还可以使用这个 key(list)数组(array)
public Employee getEmpById(List ids);
取值:取出第一个 id 的值: #{list[0]}
总结:参数多时会封装 map,为了不混乱,我们可以使用 @Param 来指定封装时使用的 key;
#{key}就可以取出 map 中的值
===========================参数值的获取======================================
#{}:可以获取 map 中的值或者 pojo 对象属性的值;
${}:可以获取 map 中的值或者 pojo 对象属性的值;

select * from tbl_employee where id=${id} and last_name=#{lastName}
Preparing: select * from tbl_employee where id=2 and last_name=?
	区别:
		#{}:是以预编译的形式,将参数设置到sql语句中;PreparedStatement;防止sql注入
		${}:取出的值直接拼装在sql语句中;会有安全问题;
		大多情况下,我们去参数的值都应该去使用#{};
		
		原生jdbc不支持占位符的地方我们就可以使用${}进行取值
		比如分表、排序。。。;按照年份分表拆分
			select * from ${year}_salary where xxx;
			select * from tbl_employee order by ${f_name} ${order}

#{}:更丰富的用法:
规定参数的一些规则:
javaType、 jdbcType、 mode(存储过程)、 numericScale、
resultMap、 typeHandler、 jdbcTypeName、

  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    170 引用 • 414 回帖 • 429 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    330 引用 • 614 回帖
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    34 引用 • 467 回帖 • 693 关注
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    103 引用 • 294 回帖
  • 大数据

    大数据(big data)是指无法在一定时间范围内用常规软件工具进行捕捉、管理和处理的数据集合,是需要新处理模式才能具有更强的决策力、洞察发现力和流程优化能力的海量、高增长率和多样化的信息资产。

    89 引用 • 113 回帖
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 3 关注
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 643 关注
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 41 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    275 引用 • 682 回帖
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    6554 引用 • 29428 回帖 • 246 关注
  • OnlyOffice
    4 引用 • 23 关注
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    163 引用 • 1450 回帖
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 423 关注
  • 创业

    你比 99% 的人都优秀么?

    82 引用 • 1398 回帖 • 1 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖 • 1 关注
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    89 引用 • 345 回帖
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖
  • 运维

    互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。

    148 引用 • 257 回帖
  • JRebel

    JRebel 是一款 Java 虚拟机插件,它使得 Java 程序员能在不进行重部署的情况下,即时看到代码的改变对一个应用程序带来的影响。

    26 引用 • 78 回帖 • 623 关注
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 685 关注
  • 招聘

    哪里都缺人,哪里都不缺人。

    189 引用 • 1056 回帖
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    324 引用 • 1395 回帖
  • 游戏

    沉迷游戏伤身,强撸灰飞烟灭。

    169 引用 • 799 回帖
  • Unity

    Unity 是由 Unity Technologies 开发的一个让开发者可以轻松创建诸如 2D、3D 多平台的综合型游戏开发工具,是一个全面整合的专业游戏引擎。

    25 引用 • 7 回帖 • 245 关注
  • 导航

    各种网址链接、内容导航。

    37 引用 • 168 回帖 • 1 关注
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    129 引用 • 793 回帖