mybatis参数传递:

单个参数:不做特殊处理
        #{参数名}:取出参数值
    多个参数:做特殊处理
        多个参数会被封装成一个map
            key:param1   ...   paramN
            value:传入的参数值
        #{}就是从map中获取指定的key值
        
        操作:
            方法:public Employee getEmployeeByNmaeAndPass(String name,String pass);
            取值:#{name},#{pass}

命名参数:明确指定封装参数时map的key:@Param("id")
        多个参数会被封装成一个map
            key:使用@Param注解指定的值
            value:参数值
            #{指定的key}取出对应的参数值

POJO:

如果多个参数是业务模型中的数据,可以直接使用POJO:
            #{属性名}:取出传入的POJO 的属性值

Map:

如果多个参数不是业务模型中的数据,没有对应的POJO,为了方便,可以传入map
            #{key}:取出map中对应的值

TO:
    如果多个参数不是业务模型中的数据,但是经常要是用,推荐来编写一个TO(Transfer Object)数据传输对象
    Page{
        int index;
        int size;
    }

示例:

1、public Employee getEmployee(@Param("name")String name,String pass);
    取值:name=====>#{name/param1}   pass=====>#{param2}

2、public Employee getEmployee(String name,@Param("emp")Employee employee);
    取值:name====>#{param1}      pass=====>#{emp.pass/param2.pass}

3、如果是Collection(List   Set)类型或者是数组型,也会特殊处理,
    也是把传入的list或者数组封装在map中
        key:Collection(collection),如果是List还可以使用这个key(list)
             数组(array)
    public Employee getEmpById(List<Integer> ids);
    取值:取出第一个id的值:#{list[0]}

mybatis处理参数:
总结:参数多时会封装map,未了不混乱,可以使用@Param来指定封装时使用的key;
#{key}就可以取出map中的值

(@Param("id")Integer id,@Param("name")String name);
ParamNameResolver解析参数封装的map:
    names:{0=id,1=name}
    1、获取每个标了param注解的参数的@Param的值:id,name:赋值给name
    2、每次解析一个参数给map中保存信息:(key:参数索引,value:name的值)
        name的值:
            标注了param注解:注解值
            没有标注:
            1、全局配置:userActualParam(jdk1.8):name=参数名
            2、name=map.size();相当于当前元素索引

mybatis参数值的获取
#{}:可以获取map中的值或者pojo对象属性的值
${}: 可以获取map中的值或者pojo对象属性的值
区别:
    #{}:是以预编译的形式,将参数设置到sql语句中:PreparedStatement;防止sql注入
    ${}:取出的值,直接拼接在sql语句中,会由安全问题;
    大多情况下,都会使用#{}
    当存在分表、排序:按照年份分表拆分
        原生jdbc不支持占位符的地方就可以使用${}进行取值
        select * from  ${year}_salary where xxxx;
        select * from tb_student order by ${name}
        
#{}:
    可以规定参数的一些规则:
    JavaType、jdbcType、mode(存储过程)、numeriScale、resultMap、typeHandler、jdbcTypeName

jdbcType通常需要在某种特定的条件下呗被设置:
        在数据为null的时候,有些数据库可能不能识别mybatis对null的默认处理。
        比如:Oracle(报错)
        insert into student(id,name,age) values(null,'test',null)
        oracle不能识别对null的操作,报错。因为mybatis对所有的null都映射的是原生jdbc的other类型。
        但是MySQL可以识别对null的操作,若想解决此问题,则使用以下添加语句;
        
        1、insert into student(id,name,age) values(#{id},#{name},#{age,jdbcType=NULL})
    
        2、由于全局配置中,jdbcTypeForNull=OTHER:oracle不支持
            <setting name="jdbcTypeForNull" value="NULL">
            此配置对使用MySQL数据库时的影响。

返回参数类型:
List型:
    resultType:返回的是一个集合,要写集合中元素的类型

Map型:
    resultType=“map”:返回一条记录
    key:就是列名    value:对应的值
    mybatis对用到的部分类进行了封装,可直接使用封装类型。

返回多条记录封装一个map:
    1、resultType:要写集合中元素的类型。
        Map<Integer,Employee>:
                键是这条记录的主键,值是记录封装后的JavaBean
    2、在对应的方法上添加@MapKey("id") 告诉mybatis封装这个map的时候使用哪个属性作为map的key

Mybatis参数传递及返回类型的更多相关文章

  1. 使用MyBatis查询 返回类型为int,但是当查询结果为空NULL,报异常的解决方法

    使用MyBatis查询 返回类型为int,但是当查询结果为空NULL,会报异常. 例如: <select id="getPersonRecordId" parameterTy ...

  2. mybatis中查询结果为空时不同返回类型对应返回值

    今天在别人的代码基础上实现新需求,看到对于mybatis查询结果的判断不是很正确,如果查询结果为空就会异常,不知道大家有没有这样的疑惑:mybatis中resultType有多种返回类型,对于每种不同 ...

  3. mybatis默认返回类型

    在mybatis中,无论你指定还是不指定返回类型,mybatis都会默认的先将查询回的值放入一个hashMap中(如果返回的值不止一条就是一个包含hashMap的list).这其中的区别在于,如果你指 ...

  4. C/C++函数调用的几种方式及函数名修饰规则以及c++为什么不允许重载仅返回类型不同的函数

    我们知道,调用函数时,计算机常用栈来存放函数执行需要的参数,由于栈的空间大小是有限的,在windows下栈是向低地址扩展的数据结构,是一块连续的内存区域.这句话的意思是栈顶的地址和栈的最大容量是系统预 ...

  5. mybatis 调用存储过程 返回游标 实例

    存储过程示例: create or replace procedure Fsp_Plan_CheckPrj(v_grantno varchar2, v_deptcode number, v_curso ...

  6. MyBatis返回主键,MyBatis Insert操作返回主键

    MyBatis返回主键,MyBatis Insert操作返回主键 >>>>>>>>>>>>>>>>> ...

  7. Mybatis批量insert 返回主键值和foreach标签详解

    Mybatis批量insert 返回主键 Mybatis从3.3.1版本开始,支持批量插入后返回主键ID.首先对于支持自增主键的数据库使用useGenerateKeys和keyProperty,对于不 ...

  8. 函数----基础,参数传递,返回类型和return语句

    一.函数基础1.形参和实参 实参是形参的初始值.第一个实参初始化第一个形参,第二个实参初始化第二个形参,以此类推.尽管实参与形参存在对应关系,但是并没有规定实参的求值顺序.编译器能以任意可行的顺序对实 ...

  9. mybatis+sqlserver中返回非自增主键

    首先把实体类贴出来(这里只贴出属性,其它的就是getter和setter方法): public class Around {     private String xccd;  //对应主键      ...

随机推荐

  1. “随手记”开发记录day15

    今天完成了前两天没有完成的增加“修改”功能.对于已经添加的记账记录,长按可以进行修改和删除的操作.

  2. Java集合最全解析,学集合,看这篇就够用了!!!

    在看集合类之前, 我们要先明白一下概念: 1.数据结构 (1):线性表 [1]:顺序存储结构(也叫顺序表) 一个线性表是n个具有相同特性的数据元素的有限序列.数据元素是一个抽象的符号,其具体含义在不同 ...

  3. Docker 启动 OpenResty

    Docker 启动 OpenResty OpenResty 是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库.第三方模块以及大多数的依赖项.用于方便地搭建 ...

  4. ECS7天实践进阶训练营Day2:基于阿里云ECS部署MediaWiki

    一.概述 MediaWiki是全球最著名的开源Wiki程序,运行于PHP+MySQL环境,MediaWiki从2002年被作为维基百科的系统软件,并由大量其他应用实例(例如萌娘百科),因此MediaW ...

  5. FPN和他的子孙们

    FPN 方框里表示top down里每层有两个卷积操作  PAN:添加一个 bottom up线 NAS-FPN:基于搜索结构的FPN  Fully-conencted FPN:全连接的FPN  Si ...

  6. c++萌新到大牛,要看哪些书?

    基础语法 <c++primer> 语法进阶 <c++primer plus> 专为c++编著.支持c++14国际标准. 数据结构和算法 <大话数据结构> 编程规范 ...

  7. ALGEBRA-2 有限维向量空间

    关键词:张成.线性无关.基.维度 linear span:  V中任意一组向量的span都是V的子空间(对加法和数乘封闭) linear independent 线性无关 https://www.zy ...

  8. Android Studio Gradle build 报错:Received status code 400 from server: Bad Request

    错误提示如下 Could not GET 'https://dl.google.com/dl/android/maven2/com/android/tools/build/gradle/3.1.2/ ...

  9. Spring Cloud Config Client 超时与重试

    简介 有时客户端需要在 config server 无响应时进行重试,以给 config server 时间进行恢复.利用 spring 提供的重试组件,我们可以方便的配置重试机制,包括重试间隔,重试 ...

  10. Vue管理系统前端系列二相关工具引入及封装

    目录 sass-loader/vuex 等的引入说明 引入 element 引入 axios 1.基本使用 2.封装使用 2.1 开发环境配置请求地址 2.2 配置代理 2.3 添加接口相关文件 sa ...