博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
<MyBatis>入门四 传入的参数处理
阅读量:5033 次
发布时间:2019-06-12

本文共 2218 字,大约阅读时间需要 7 分钟。

1.单个参数

  传入单个参数时,mapper文件中 #{}里可以写任意值

/**     * 传入单个参数     */    Employee getEmpById(Integer id);

2.多个参数

/**     * 传入多个参数     */    Employee getEmpByIdAndName(Integer id,String name);

  此时会报错 Caused by: org.apache.ibatis.binding.BindingException:Parameter 'id' not found. Available parameters are [arg1, arg0, param1, param2]

  传入多个参数时,mybatis会做特殊处理,

  将多个参数封装成一个map,key是param1...paramN#{},从map中获取指定的key值

解决办法

  1、使用param1..paramN,

  2.使用方法1,并不能见名知意,所以推荐第二种方法

    命名参数,明确指定封装参数的map,

        key:使用@Param注解指定的值

        这样就可以通过#{}来取值

/**     * 传入多个参数     */    Employee getEmpByIdAndGender(@Param("id") Integer id, @Param("gender") Character gender);

3 .传入pojo

  如果多个参数正好是我们业务逻辑的数据模型,直接传入POJO,#{属性名}:取出POJO属性值

/**     * 传入pojo     */    Employee getEmpByIdAndNamePojo(Employee employee);

4.传入Map

  如果多个参数不是业务模型中的数据,没有对应的POJO,不经常使用,为了方便,我们传入map

/**     * 传入map     */    Employee getEmpByMap(Map
map);
Map
map = new HashMap<>(); map.put("id",1); map.put("name","tom"); Employee emp = mapper.getEmpByMap(map);

5.传入TO(transfer Object)

  多个参数不是业务中的模型,但是要经常使用,推荐写一个TO,数据传输对象。

6.思考

  

 7.${},#{}区别

  #{}:是以预编译的形式,将参数设置到sql语句中,PreparedStatement;防止sql注入

  ${}:取出的值直接拼装在sql语句中;会有安全问题

  大多情况下,取参数使用#{}

  比如分表,select * from ${year}_salary where xxx;

  原生不支持占位符的:select * from tbl_employee order by ${name} ${order} 

8.#{}的用法

  

 

转载于:https://www.cnblogs.com/mapleins/p/10113343.html

你可能感兴趣的文章
基础_模型迁移_CBIR_augmentation
查看>>
第二次寒假作业
查看>>
类与 对象 概念 break continue
查看>>
tensorRT使用python进行网络定义
查看>>
[转]从程序员到项目经理(三):认识项目经理
查看>>
深度分析如何在Hadoop中控制Map的数量
查看>>
dede判断当前文章
查看>>
mpvue学习笔记
查看>>
[LeetCode] 628. Maximum Product of Three Numbers_Easy
查看>>
[Java in NetBeans] Lesson 06. Custom classes
查看>>
[AngularFire2 & Firestore] Example for collection and doc
查看>>
[Javascript] The "this" keyword
查看>>
ElasticSearch-5.3.1集群环境搭建,安装ElasticSearch-head插件,安装错误解决
查看>>
sharepoint Report使用共享数据源部署报错
查看>>
C++ Primer 5th 第16章 模板与泛型编程
查看>>
22个Web 在线编辑器[转]
查看>>
解决“The superclass "javax.servlet.http.HttpServlet" was not found on the Java Build Path”问题...
查看>>
T-SQL语句学习(一)
查看>>
装箱拆箱(一)
查看>>
Python3 PyMySQL 的使用
查看>>