1.单个参数

mybatis不会做特殊处理,#{参数名/任意名}:取出参数值

例如:接口中方法 public Employee getEmpById(String empId);

XML中 <select id="getEmpById" resultType="com.mybatis.entity.Employee">

select * from t_employee where empId=#{empId}

</select>

    注意:List集合或数组需@Param指定参数名

2.多个参数

2.1 不使用@Param  不推荐

mybatis会做特殊处理,多个参数会被封装成 一个map

key:param1...paramN,或者参数的索引也可以

value:传入的参数值

#{key}取出对应的参数值

    例如:接口中方法 public List<Employee> getEmpsByempNameAndSex(String empName,Integer empSex);

XML中  <select id="getEmpsByempNameAndSex" resultType="com.mybatis.entity.Employee">

 select * from t_employee where empName=#{} and empSex=#{}
                            </select>

                            或者

                           <select id="getEmpsByempNameAndSex" resultType="com.mybatis.entity.Employee">

 select * from t_employee where empName=#{param1} and empSex=#{param2}
                           </select>

2.2 使用@Param

明确指定封装参数时map的key,多个参数会被封装成 一个map

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

value:参数值

#{指定的key}取出对应的参数值

例如:接口中方法 public List<Employee> getEmpsByempNameAndSex(@Param("empName")String empName,@Param("empSex")Integer empSex);

XML中 <select id="getEmpsByempNameAndSex" resultType="com.mybatis.entity.Employee">

select * from t_employee where empName=#{empName} and empSex=#{empSex}

</select>

2.3 Map传参

#{key}:取出map中对应的值

例如:接口中方法 public List<Employee> getEmpsByempNameAndSex(Map<String, Object> map);

XML中 <select id="getEmpsByempNameAndSex" resultType="com.mybatis.entity.Employee">

 select * from t_employee where empName=#{empName} and empSex=#{empSex}

</select>

                测试代码

                            Map<String, Object> map=new HashMap<>();

                            map.put("empName", "王昭君");

                            map.put("empSex", 0);

   3.Bean参数 

     如果多个参数正好是我们业务逻辑的数据模型,我们就可以直接传入pojo

#{属性名}:取出传入的pojo的属性值

例如:接口中方法 public Integer addEmployee(Employee employee);

XML中 <insert id="addEmployee" parameterType="com.mybatis.entity.Employee">

                               insert into t_employee(empId,empName,empSex,empAge) values(#{empId},#{empName},#{empSex},#{empAge})

                            </insert>

MyBatis探究-----传递参数详解的更多相关文章

  1. MyBatis探究-----动态SQL详解

    1.if标签 接口中方法:public List<Employee> getEmpsByEmpProperties(Employee employee); XML中:where 1=1必不 ...

  2. Android事件传递机制详解及最新源码分析——ViewGroup篇

    版权声明:本文出自汪磊的博客,转载请务必注明出处. 在上一篇<Android事件传递机制详解及最新源码分析--View篇>中,详细讲解了View事件的传递机制,没掌握或者掌握不扎实的小伙伴 ...

  3. Mybatis SQL映射文件详解

    Mybatis SQL映射文件详解 mybatis除了有全局配置文件,还有映射文件,在映射文件中可以编写以下的顶级元素标签: cache – 该命名空间的缓存配置. cache-ref – 引用其它命 ...

  4. Mybatis系列全解(四):全网最全!Mybatis配置文件XML全貌详解

    封面:洛小汐 作者:潘潘 做大事和做小事的难度是一样的.两者都会消耗你的时间和精力,所以如果决心做事,就要做大事,要确保你的梦想值得追求,未来的收获可以配得上你的努力. 前言 上一篇文章 <My ...

  5. iptables参数详解

    iptables参数详解 搬运工:尹正杰 注:此片文章来源于linux社区. Iptalbes 是用来设置.维护和检查Linux内核的IP包过滤规则的. 可以定义不同的表,每个表都包含几个内部的链,也 ...

  6. mha配置参数详解

    mha配置参数详解: 参数名字 是否必须 参数作用域 默认值 示例 hostname Yes Local Only - hostname=mysql_server1, hostname=192.168 ...

  7. $.ajax()方法所有参数详解;$.get(),$.post(),$.getJSON(),$.ajax()详解

    [一]$.ajax()所有参数详解 url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. type: 要求为String类型的参数,请求方式(post或get)默认为get.注 ...

  8. MyBatis的动态SQL详解

    MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑,本文详解mybatis的动态sql,需要的朋友可以参考下 MyBatis 的一个强大的特性之一通常是它 ...

  9. 【转】jqGrid 各种参数 详解

      [原文]http://www.cnblogs.com/younggun/archive/2012/08/27/2657922.htmljqGrid 各种参数 详解 JQGrid JQGrid是一个 ...

随机推荐

  1. jupyter notebook 远程访问

    https://www.youtube.com/watch?v=LpQl0yeZzCU 在服务器端执行: jupyter notebook --ip 服务器的Ip地址 --allow-root --n ...

  2. MyBatis入门(二)接口式编程

    在  MyBatis入门(一) 的基础之上编写接口 将接口和Mapper文件进行绑定,会为接口创建一个代理对象,代理对象去执行增删改查 (1)编写接口 public interface EmpDao ...

  3. JS功能函数

    1.整数每三位增加一个, function toThousands(num) {      return (num || 0).toString().replace(/(\d)(?=(?:\d{3}) ...

  4. linux学习:归档,备份及进程相关命令用法整理

    指令:tar.zip.gzip.unzip.rsync.scp.ps.kill.nohup 压缩 tar 归档命令,不具备压缩功能 tar -zcvf test.tar.gz  test/     # ...

  5. python全栈开发 * background 定位 z-index * 180813

    I back-ground 一.颜色的表示: 1.单词 2.rgb表示法 rgb:红色 绿色 蓝色 三原色 光学显示器每个像素都是由三原色的发光原件组成的,靠明亮度不同调成不同的颜色的. 用逗号隔开, ...

  6. 架构.Net 到 Linux

    nginx + .net core + mysql + radis + rabbitmq

  7. Enable Coded UI Testing of Your Controls

    http://msdn.microsoft.com/en-us/library/hh552522.aspx AccessibleObject Class http://msdn.microsoft.c ...

  8. mysql千万级数据量查询出所有重复的记录

    查询重复的字段需要创建索引,多个条件则创建组合索引,各个条件的索引都存在则不必须创建组合索引 有些情况直接使用GROUP BY HAVING则能直接解决:但是有些情况下查询缓慢,则需要使用下面其他的方 ...

  9. 利用GCD 中的 dispatch_source_timer 给tableViewCell添加动态刷新的计时/倒计时功能

    1.思路一(失败) 在设置好cell 里的内容之后在每个cell 返回时调用定时器事件,更新cell 内容,然后刷新整个表格. - (void)didadida:(UITableViewCell *) ...

  10. /etc/init.d/sshd配置SSHD路径忘记修改导致启动失败

    [root@lnlte2dmr3 ~]# bash[root@lnlte2dmr3 ~]# install -v -m700 -d /var/empty/sshdinstall: 正在创建目录&quo ...