、单个参数 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. mysql数据字典 如何生成?

    用phpMyAdmin查看表结构,点击 打印预览. &amp;lt;img src="https://pic3.zhimg.com/50/3205ff3bd3da067528f4c1 ...

  2. QT使用SQLite

    在QT的widget中用tableview显示sqlite数据库表中的内容. 用QTcreator创建一个基于Widget类的窗口,再拖一个tableview到widget中,保存. 1.在widge ...

  3. PHP $a='abcdef';请取出$a的值并打印第一个字母

    echo $a[0];echo $a{0};echo chr(ord($a));echo substr( $a, 0,1);

  4. 用Matlab进行部分分式展开

    [r p k]=residue[num,den] 例如H(s)=(2s3+5s2+3s+6)/(s3+6s2+11s+6) num=[2 5 3 6]; den=[1 6 11 6]; [r p k] ...

  5. 解决下载经过GZip压缩后的网页乱码问题

    目前很多网站默认采用GZip压缩,如果不进行解压缩,下载后生成的html页面打开后会出现中文乱码 乱码前: string url = "http://quote.eastmoney.com/ ...

  6. ghost之后仍然中病毒----与病毒的斗争

    ghost之后仍然中病毒----与病毒的斗争我的电脑系统是XP,从来都没有安装任何杀毒软件,所有的软件都是安装在C盘的,感觉系统卡顿就用Windows一键还原(基于DOS下的ghost)还原一下,一直 ...

  7. Javascript中的对象(八)

    一.如何编写可以计算的对象的属性名 我们都知道对象的属性访问分两种,键访问(["属性名"])和属性访问(.属性名,遵循标识符的命名规范) 对于动态属性名可以这样 var prefi ...

  8. github_源码

      固定头部: hongyangAndroid/Android-StickyNavLayout:ListView 与ViewPager 滑动冲突处理,滑动到顶部固定位置停顿; ufo22940268/ ...

  9. python面向对象 : 抽象类(接口类),多态,封装(私有制封装)

    一. 抽象类(接口类) 与java一样, python也有抽象类的概念但是同样需要借助模块实现,抽象类是一个特殊的类, 它的特殊之处在于只能被继承, 不能被实例化. 从设计角度去看, 如果类是从现实对 ...

  10. ArcMap VBA实现连续编号

    连续编号VBA部分:Static lCount as longlCount=lCount+1赋值部分:lCount (从1开始)lCount-1 (从0开始)