Mybatis参数传递及返回类型
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参数传递及返回类型的更多相关文章
- 使用MyBatis查询 返回类型为int,但是当查询结果为空NULL,报异常的解决方法
使用MyBatis查询 返回类型为int,但是当查询结果为空NULL,会报异常. 例如: <select id="getPersonRecordId" parameterTy ...
- mybatis中查询结果为空时不同返回类型对应返回值
今天在别人的代码基础上实现新需求,看到对于mybatis查询结果的判断不是很正确,如果查询结果为空就会异常,不知道大家有没有这样的疑惑:mybatis中resultType有多种返回类型,对于每种不同 ...
- mybatis默认返回类型
在mybatis中,无论你指定还是不指定返回类型,mybatis都会默认的先将查询回的值放入一个hashMap中(如果返回的值不止一条就是一个包含hashMap的list).这其中的区别在于,如果你指 ...
- C/C++函数调用的几种方式及函数名修饰规则以及c++为什么不允许重载仅返回类型不同的函数
我们知道,调用函数时,计算机常用栈来存放函数执行需要的参数,由于栈的空间大小是有限的,在windows下栈是向低地址扩展的数据结构,是一块连续的内存区域.这句话的意思是栈顶的地址和栈的最大容量是系统预 ...
- mybatis 调用存储过程 返回游标 实例
存储过程示例: create or replace procedure Fsp_Plan_CheckPrj(v_grantno varchar2, v_deptcode number, v_curso ...
- MyBatis返回主键,MyBatis Insert操作返回主键
MyBatis返回主键,MyBatis Insert操作返回主键 >>>>>>>>>>>>>>>>> ...
- Mybatis批量insert 返回主键值和foreach标签详解
Mybatis批量insert 返回主键 Mybatis从3.3.1版本开始,支持批量插入后返回主键ID.首先对于支持自增主键的数据库使用useGenerateKeys和keyProperty,对于不 ...
- 函数----基础,参数传递,返回类型和return语句
一.函数基础1.形参和实参 实参是形参的初始值.第一个实参初始化第一个形参,第二个实参初始化第二个形参,以此类推.尽管实参与形参存在对应关系,但是并没有规定实参的求值顺序.编译器能以任意可行的顺序对实 ...
- mybatis+sqlserver中返回非自增主键
首先把实体类贴出来(这里只贴出属性,其它的就是getter和setter方法): public class Around { private String xccd; //对应主键 ...
随机推荐
- 最全总结!聊聊 Python 调用 JS 的几种方式
1. 前言 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手.很多已经做案例的人,却不知道如何去学习更加高深的知识.那么针对这三类人,我给大 ...
- 18、Java中的 数据结构
Java2中引入了新的数据结构 集合框架 Collection,下一节再谈论(非常重要,面试也常问). 1.枚举 (Enumeration) 1.1 Enumeration 源码: public in ...
- 面试中的老大难-mysql事务和锁,一次性讲清楚!
众所周知,事务和锁是mysql中非常重要功能,同时也是面试的重点和难点.本文会详细介绍事务和锁的相关概念及其实现原理,相信大家看完之后,一定会对事务和锁有更加深入的理解. 本文主要内容是根据掘金小册& ...
- 解析Class文件之创建InstanceKlass对象
ClassFileParser::parseClassFile()方法会将解析Class文件的大部分结果保存到instanceKlass对象中.创建instanceKlass对象的代码如下: int ...
- 可以用命令行控制eclipse断点增加删除、远程调试创建与启动的插件
java # 创建断点(支持条件断点) curl -X PUT -H "Content-Type:application/json" --data '{"language ...
- 利用C#实现OPC-UA服务端
前言 最近接手了一个项目,做一个 OPC-UA 服务端?刚听到这个消息我是一脸懵,发自灵魂的三问“OPC-UA是什么?”.“要怎么做?”.“有什么用?”.我之前都是做互联网相关的东西,这种物联网的还真 ...
- Android Studio && GitHub 团队多人一起开发
曾几何时,花了两天的时间搞了合并项目,搞得乱七八糟der,但最终还是被我搞定了,too 乱 to 做笔记.过了几个月,也就是前几天,抱着从头开始的决心,再次尝试,然鹅并没有结果.今天,再一次重新开始, ...
- PythonCrashCourse 第二章习题
2.3 个性化消息:将用户的姓名存到一个变量中,并向该用户显示一条消息.显示的消息应非常简单,如"Hello Eric, would you like to learn some Pytho ...
- C++类和对象的封装 点和圆的案例
主要练习 :在类中可以让另一个类作为本类的成员. 案例:判断点和圆的位置关系. 一.第一种直接方法 using namespace std; #include <iostream> cla ...
- linux修改最大的文件描述符(max file descriptors)
用xshell登录linux系统之后,用命令>ulimit -a 注意到系统模式是1024个 使用>ulimit -n 数量,可临时更改,生效范围为当前会话 永久修改的方法: > v ...