、单个参数 mybatis不会做特殊处理。

  #{参数名/任意名}:取出参数值。

、多个参数 mybatis会做特殊处理。

  多个参数会被封装成 一个map。

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

  value:传入的参数值。

  #{}就是从map中获取指定的key的值;

  多个参数传递的时候要使用命名参数的形式:

、命名参数:明确指定封装参数时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;
    } 、例子: public Employee getEmp(@Param("id")Integer id,String lastName);
取值:id==>#{id/param1} lastName==>#{param2} public Employee getEmp(Integer id,@Param("e")Employee emp);
取值:id==>#{param1} lastName===>#{param2.lastName/e.lastName}
  特别注意: 如果是Collection(List、Set)类型或者是数组,也会特殊处理。也是把传入的list或者数组封装在map中。   key的取值:       key:Collection(collection)。          List(list)          数组(array) public Employee getEmpById(List<Integer> ids);
取值:取出第一个id的值: #{list[]}
、参数值的获取   #{}:可以获取map中的值或者pojo对象属性的值;   ${}:可以获取map中的值或者pojo对象属性的值; select * from tbl_employee where id=${id} and last_name=#{lastName}
Preparing: select * from tbl_employee where id= and last_name=?
  区别:     #{}:是以预编译的形式,将参数设置到sql语句中;PreparedStatement;防止sql注入。     ${}:取出的值直接拼装在sql语句中;会有安全问题;大多情况下,我们去参数的值都应该去使用#{};   原生jdbc不支持占位符的地方我们就可以使用${}进行取值,比如分表、排序。。。;按照年份分表拆分  select * from ${year}_salary where xxx;
select * from tbl_employee order by ${f_name} ${order}
、#{}:更丰富的用法:   规定参数的一些规则:   javaType、 jdbcType、 mode(存储过程)、 numericScale、   resultMap、 typeHandler、 jdbcTypeName、 expression(未来准备支持的功能);   jdbcType通常需要在某种特定的条件下被设置:     在我们数据为null的时候,有些数据库可能不能识别mybatis对null的默认处理。比如Oracle(报错);     JdbcType OTHER:无效的类型;因为mybatis对所有的null都映射的是原生Jdbc的OTHER类型,oracle不能正确处理;     由于全局配置中:jdbcTypeForNull=OTHER;oracle不支持;两种办法     、#{email,jdbcType=OTHER};     、jdbcTypeForNull=NULL        <setting name="jdbcTypeForNull" value="NULL"/>

二、封装MAP

//返回一个map,key是列名,value是值
public Map<String,Object> getUserByIdReturnMap(Integer id);
//返回一个map,key是主键,value是值
@MapKey("id")
public Map<Integer,User> getUserByLastName(String lastName);

mapper配置

     <select id="getUserByLastName" resultType="model.User">
SELECT * FROM
user WHERE last_name like "%"#{lastName}"%"
</select>
<select id="getUserByIdReturnMap" resultType="map">
SELECT * FROM
user WHERE id=#{id}
</select>

三、自定义返回值类型

<1>

实体类定义别名

@Alias("user")
public class User { private int id;
private String lastName;
private String email;
private String gender;

public User selectUserById(Integer id);方法

mapper配置

<!-- 自定义javabeen的规则
type自定义java规则
id 唯一id方便引用
column:指定哪一列
property:指定javaBean属性
-->
<resultMap type="user" id="Myuser">
<id column="id" property="id"/>
<result column="last_name" property="lastName"/>
<result column="email" property="email"/>
<result column="gender" property="gender"/>
</resultMap>
<select id="selectUserById" resultMap="Myuser">
SELECT * FROM
user WHERE id=#{id}
</select>

<2>

@Alias("user")
public class User { private int id;
private String lastName;
private String email;
private String gender;
private Department dept;
@Alias("depart")
public class Department { private Integer id;
private String departName;

public User selectUserAndDepart(Integer id);

mapper配置

<resultMap type="user" id="Mymap">
<id column="id" property="id"/>
<result column="last_name" property="lastName"/>
<result column="email" property="email"/>
<result column="gender" property="gender"/>
<result column="depart_id" property="dept.id"/>
<result column="depart_name" property="dept.departName"/>
</resultMap>
<select id="selectUserAndDepart" resultMap="Mymap">
SELECT u.id,u.depart_id,u.email,u.gender,u.last_name,d.depart_name FROM USER
u,department d WHERE u.depart_id=d.id AND u.id=#{id}
</select>

mapper配置2

<resultMap type="user" id="Mymap2">
<id column="id" property="id"/>
<result column="last_name" property="lastName"/>
<result column="email" property="email"/>
<result column="gender" property="gender"/>
<association property="dept" javaType="depart">
<id column="id" property="id"/>
<result column="depart_name" property="departName"/>
</association>
</resultMap>

<select id="selectUserAndDepart" resultMap="Mymap2">
SELECT u.id,u.depart_id,u.email,u.gender,u.last_name,d.depart_name FROM USER
u,department d WHERE u.depart_id=d.id AND u.id=#{id}
</select>

<3>分布查询

<resultMap type="user" id="stepMap">
<id column="id" property="id"/>
<result column="last_name" property="lastName"/>
<result column="email" property="email"/>
<result column="gender" property="gender"/>
<association property="dept" select="mapper.DepartMapper.selectDepartById" column="depart_id" >
    
<association property="dept" select="mapper.DepartMapper.selectDepartById" column="{id=depart_id}" fetchType="eager">
</association>
{key1=column1,key2=column2}(多个参数) fetchType="lazy"(延迟加载)||"eager"(立刻加载)
        </association>
</resultMap>
<!-- 分布查询 -->
<select id="selectUserByIdStep" resultMap="stepMap">
SELECT * FROM USER WHERE id =#{id}
</select>
<mapper namespace="mapper.DepartMapper">
<select id="selectDepartById" resultType="depart">
SELECT * FROM
department WHERE id=#{id}
</select>
</mapper>

mybatis二(参数处理和map封装及自定义resultMap)的更多相关文章

  1. Mybatis传入参数类型为Map

    mybatis更新sql语句: <update id="publishT00_notice" parameterType="Map"> update ...

  2. 【batch】批处理文件多参数处理和for循环字符串连接

    batch文件写起来,酸爽不谈了.[1]今天在github上发现个好东西batsh,运行地址:https://batsh.org/.[1] 这里需求的场景是:调用run.bat脚本并传入多个参数(相对 ...

  3. MyBatis(二):Select语句传递参数的集中方案

    从别人说的方案中看出,传递参数方案还挺多,不如自己整理下,以便以后使用过程中有个笔记回忆录. 1.传递一个参数的用法: 配置文件 <select id="getById" r ...

  4. MyBatis传入集合 list 数组 map参数的写法

    foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合.foreach元素的属性主要有item,index,collection,open,separator,close.ite ...

  5. MyBatis传入参数为list、数组、map写法(转载)

    MyBatis传入参数为list.数组.map写法 1.foreach简单介绍: foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合. foreach元素的属性主要有item ...

  6. MyBatis传入参数为list、数组、map写法

    1.foreach简单介绍: foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合. foreach元素的属性主要有item,index,collection,open,sep ...

  7. 学习笔记:CentOS7学习之二十五:shell中色彩处理和awk使用技巧

    目录 学习笔记:CentOS7学习之二十五:shell中色彩处理和awk使用技巧 25.1 Shell中的色彩处理 25.2 awk基本应用 25.2.1 概念 25.2.2实例演示 25.3 awk ...

  8. 【转载】Mybatis多参数查询映射

    转载地址:http://www.07net01.com/zhishi/402787.html 最近在做一个Mybatis的项目,由于是接触不久,虽然看了一下资料,但在实际开发中还是暴 露了很多问题,其 ...

  9. 【MyBatis】解析MyBatis传入参数的问题

    一.单个参数: public List<XXBean> getXXBeanList(String xxCode); <select id="getXXXBeanList&q ...

随机推荐

  1. .net core 连接sql server 时提示Connection Timeout Expired

    .net core开发环境是ubuntu LINUX, 在ubuntu 上 telnet 数据库IP 端口是通的. SQL SERVER 是2008 ,未打SP补丁. 打完 SQL SERVER  2 ...

  2. ALGO-31_蓝桥杯_算法训练_开心的金明(DP)

    问题描述 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间他自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:“你的房间需要购买哪些物品,怎 么布置,你说了算,只要不超过N元钱就行”.今 ...

  3. asp.net控件拖不动。控件错误

    有一种可能是工程的存储路径名称不规范导致,更改命名空间及路径. 我的存储路径是C#文件夹下,去掉#完美解决

  4. ssh连接docker容器

    有两种方法: 1.通过宿主机的端口映射访问docker 在宿主机上启动容器,分配端口,启用ssh服务: docker run -p 10022:22 -d sshd:ubuntu /usr/sbin/ ...

  5. 注入 - Ring3 APC注入

    系统产生一个软中断,当线程再次被唤醒时,此线程会首先执行APC队列中的被注册的函数,利用QueueUserAPC()这个API,并以此去执行我们的DLL加载代码,进而完成DLL注入的目的, 1.根据进 ...

  6. host文件的工作原理及应用

    host文件的工作原理及应用 Hosts文件是一个用于存储计算机网络中节点信息的文件,它可以将主机名映射到相应的IP地址,实现DNS的功能,它可以由计算机的用户进行控制. 一.Hosts文件基本介绍 ...

  7. mikrotik ros CVE-2019–3924 DUDE AGENT VULNERABILITY

    原文: https://blog.mikrotik.com/security/cve-20193924-dude-agent-vulnerability.html The issue is fixed ...

  8. [UE4]在蓝图中设置图片

  9. Scala 入门详解

    Scala 入门详解 基本语法 Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的 Scala 程序是对象的集合,通过调用彼此的方法来实现消息传递.类,对象,方法,实例变 ...

  10. Linux CentOS更改文件的权限

    chgrp  (全称:change group) groupadd testgroup 添加用户组 chgrp testgroup test1 修改文件的所属用户组是testgroup. 如果test ...