1. 单个参数:mybatis不会做特殊处理

    1. 取值方式:#{参数名} 这里参数名不必与方法的形参名称一致,可以用任意参数名来接受实参
    2. 例子:方法:update(Integer id) sql映射文件取值#{a},这样也可以取到值
  2. 多个参数:mybatis会做特殊处理,即把多个参数封装成一个map ,key:param1....paramN,value:传入的参数值,#{}就是就是从map中获取指定的key的value,即#{param1},#{param2}等

  3. 多个参数处理:自定义封装参数的key

    1. 方法 get(@Param("id") Integer id,@Param("name") String name) key使用@Param注解指定的值
    2. 取值:#{id},#{name} #{自定的key}取出对应的值
  4. 如果多个参数正好是我们业务逻辑的数据模型(可以只是模型的部分数据)就可以直接传入pojo

    1. #{属性名}取出传入的pojo属性值
  5. 如果多个参数不是我们我们业务逻辑的模型,没有对应的pojo,不推荐为了方便,我们可以传入map

    1. #{key}取出map中对应的值
  6. 如果多个参数不是我们我们业务逻辑的模型,但是经常使用,推荐封装成一个vo(其实就是一个简单的javabean,把所有参数封装到一个java类中)

  7. 如果形参只有一个,但是形参的类型是集合(collection,list,set)或者数组,也会做特殊处理,把它们封装到map中

    1. 如果形参是collection,那么map的key是collection
    2. 如果是collection中的list,那么map的key是list,取值#{list[0]},表示取出list中第一个元素
    3. 如果是数组,那么map的key是array,取值#{array}
  8. #{}取值和${}取值的区别

    1. #{}是以预编译的形式,将参数设置到sql中 ,利用preparedStatement,防止sql注入
    2. ${},取出的值直接拼在sql中,有安全问题
    3. 原生jdbc不支持占位符的地方zhi能用${}取值,比如分表、排序等
  9. #{}更丰富的用法

    1. 规定参数的一下规则:javaType、 jdbcType、 mode(存储过程)、 numericScale、

      resultMap、 typeHandler、 jdbcTypeName、 expression(未来准备支持的功能)

    2. jdbcType:数据库类型:通常需要在某种特定的条件下被设置:

      1. 在我们数据为null的时候,有些数据库可能不能识别mybatis对null的默认处理。比如Oracle(报错);

      2. JdbcType OTHER:无效的类型;因为mybatis对所有的null都映射的是原生Jdbc的OTHER类型,oracle不能正确处理;

      3. 由于全局配置中:jdbcTypeForNull=OTHER;oracle不支持;两种办法

        1. #{email,jdbcType=OTHER};

        2. jdbcTypeForNull=NULL

          <setting name="jdbcTypeForNull" value="NULL"/>

mybatis参数传参、取值处理等的更多相关文章

  1. Mybatis映射文件中#取值时指定参数相关规则

    Mybatis映射文件中#取值时指定参数相关规则 在#{}中,除了需要的数值外,还可以规定参数的一些其他规则. 例如:javaType,jdbcType,mode(存储过程),numericScale ...

  2. mybatis中两种取值方式?谈谈Spring框架理解?

    1.mybatis中两种取值方式? 回答:Mybatis中取值方式有几种?各自区别是什么? Mybatis取值方式就是说在Mapper文件中获取service传过来的值的方法,总共有两种方式,通过 $ ...

  3. mybatis学习$与#号取值区别

    1,多个参数传递用map或实体封装后再传给myBatis, mybatis学习$与#号取值区别 #{} 1.加了单引号,  2.#号写是可以防止sql注入,比较安全 select * from use ...

  4. python笔记之强制函数以关键字参数传参

    最近学习python,学到了函数传参,看到了以下这个特殊情况,特此来做个笔记 def add(*, x, y): print(x, y) 以上函数定义后,该怎么传参?前面的那个*号是做什么用的? 我们 ...

  5. Vue系列之 => 使用钩子函数的第二个参数传参

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. 【原】使用Builder模式替代构造参数传参

    前言:关于传递参数,当参数过多的时候我们可以考虑使用建造者模式. #没用 Builder模式 之前是这样传参的: 如下所示,构造方法里面的参数一大堆,看起来就非常的混乱. 用了Builder模式之后是 ...

  7. Hibernate的HQL语句中定位参数和具名参数传参

    HQL查询: 1.有关hql查询语句中的问号参数形式,如果出现有多个问号,这对后面设置参数就比较麻烦. 如:from User user where user.name=? and user.age= ...

  8. Java SSM框架之MyBatis3(七)MyBatis之参数取值

    在mybatis中,参数取值方式有两种:#{ } 和 ${ } 一.#{ } select * from student where name=#{name} 编译后执行的sql语句: select ...

  9. 8、SpringBoot+Mybatis整合------参数取值方式

    前言: 我们知道,在mybatis中,参数取值方式有两种: #{ } 和 ${ } 下面,我们来探讨下#{ }与${ }不同. 一.#{ } 例: select * from student wher ...

随机推荐

  1. zabbix监控之同时向多人邮件报警

    安装环境:  zabbix-server zabbix邮件报警配置步骤说明: 安装发送邮件的工具sendEmail 准备一个发送邮件的脚本 修改zabbix配置文件中指定的脚本路径 关联脚本名称 用户 ...

  2. scp 从另一台linux服务器拷贝文件或文件目录

    格式:scp [参数] [原路径] [目标路径] download 使用方法:scp -r root@127.0.0.1:/opt/soft/test /opt/soft/ scp -r 用户名@IP ...

  3. Big Data(三)伪分布式和完全分布式的搭建

    关于伪分布式的配置全程 伪分布式图示 1.安装VMWare WorkStation,直接下一步,输入激活码即可安装 2.安装Linux(需要100GB) 引导分区Boot200MB 交换分区Swap2 ...

  4. (转) weblogic 12c忘记密码

    weblogic安装后,很久不用,忘记访问控制台的用户名或者密码,可通过以下步骤来重置用户名密码. 说明:%DOMAIN_HOME%:指WebLogic Server 域(Domain)目录 我的是: ...

  5. boost多线程编译出错

    添加 -lpthread CPLUS_INCLUDE_PATH=$CPLUS_INCLUDE_PATH:/tools/boost/includeexport CPLUS_INCLUDE_PATH LI ...

  6. java map 根据 map的value值进行排序

    //根据销量排行查询 public void queryGoodsByHotCount(){ //将map集合键和值封装到entry对象中 然后转换成set集合 Set<Entry<Int ...

  7. Django初使用

    目录 一.Django初使用 1. 静态文件配置 (1)静态文件配置步骤 2. form表单的get和post提交方式 (1)get (2)post (3)注意 3. views文件中的request ...

  8. windows上部署hadoop(单机版)

    在window系统开发程序时,远程linux服务器上的hadoop速度很慢,影响开发效率,能不能在本地搭建hadoop环境的?答案肯定的,且看下文如何在window上部署hadoop: (源文地址:h ...

  9. 【NOIP2016提高A组模拟8.19】(雅礼联考day2)总结

    第一题又有gcd,又有xor,本来想直接弃疗,不过后来想到了个水法: 当两个相邻的数满足条件时,那么他们的倍数也可能满足条件.然后没打,只打了个暴力. 正解就是各种结论,各种定理搞搞. 第二题,想都不 ...

  10. Codeforces 939E Maximize ( 三分 || 二分 )

    题意 : 给出两个操作,① 往一个序列集合(初始为空)里面不降序地添加数字.② 找出当前序列集合的一个子集使得 (子集的最大元素) - (子集的平均数) 最大并且输出这个最大差值 分析 :  首先关注 ...