<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.jv.dao.EmployeeMapper"> <!-- 若是参数只有一个,在映射文件中使用${**},好比${id},若是有多个参数能够采用多参数或者POJO方式来传递,详细内容见 https://my.oschina.net/u/3049601/blog/edit --> <select id="getEmployeeById" resultType="employee" databaseId="mysql"> select employee_id,first_name,last_name,gendor,birthday from employee where employee_id=#{id} </select> <select id="getEmployeeById" resultType="employee" databaseId="oracle"> select employee_id,first_name,last_name,gendor,birthday from employee where employee_id=#{id} </select> <!-- 注意:必定要在全局配置文件中切换environments的默认environment为dev_mysql --> <!-- 由于Mysql支持主键自增,因此使用useGeneratedKeys+keyProperty两个属性能够在程序得到自增值,其内部原理就是经过Statement.getGeneratedKeys获得 useGeneratedKeys:默认值即为true keyProperty:指定javabean的主键对应的属性名称 --> <insert id="addEmployee" useGeneratedKeys="true" keyProperty="employeeId" databaseId="mysql"> <!-- 由于主键是自增的,因此不须要写ID的插入语句 --> insert into employee (first_name,last_name,gendor,birthday) values(#{firstName},#{lastName},#{gendor},#{birthday}) </insert> <!-- 由于Oracle不支持自增属性,解决方式是使用序列,所以须要得到插入记录的主键须要经过另外的方式 <selectKey>:指定得到主键的SQL keyProperty:指定javabean的主键对应的属性名称 order:有BEFORE和AFTER两种取值,建议都是BEFORE,由于使用AFTER可能会出现问题,这里也就不针对AFTER作代码演示了 resultType:javabean属性类型 --> <insert id="addEmployee" databaseId="oracle"> <selectKey databaseId="oracle" keyProperty="employeeId" order="BEFORE" resultType="Integer"> <!-- 若是<selectKey>的order属性是BEFORE,那么取序列就必须是xxx_seq.nextval,若是是AFTER,则是xxx_seq.currval --> select EMPLOYEE_ID_SEQ.nextval from dual </selectKey> <!-- 由于主键不是自增的,须要在得到主键值并设置给JAVABEAN对象后从对象中获取并插入,所以须要些主键插入SQL --> insert into employee (employee_id,first_name,last_name,gendor,birthday) values(#{employeeId},#{firstName},#{lastName},#{gendor},#{birthday}) </insert> <!-- 由于更新操做和数据库没什么差异,因此再也不指定datebaseId属性 --> <update id="updateEmployee"> update employee set first_name=#{firstName} where employee_id=#{employeeId} </update> <!-- 由于更新操做和数据库没什么差异,因此再也不指定datebaseId属性 --> <delete id="deleteEmployee" ></delete> </mapper>
Mybatis参数传递和取值详情:java
单个参数:Mybatis不会作特殊处理, #{参数名/任意名}:取出参数值。
多个参数:mybatis会作特殊处理。
1.多个参数会被封装成 一个map,
封装:mysql
key:paramName1...paramNameN,或者参数的索引也能够
value:传入的参数值
取值:sql
#{paramName}就是从map中获取指定的key的值;
操做:
方法:public Employee getEmpByIdAndLastName(Integer id,String lastName);
取值:#{id},#{lastName}数据库
2.形参了表有多个参数apache
public Employee getEmpByIdAndLastName(Integer id,String lastName);数组
错误的取值方式:#{id},#{lastName}mybatis
Mybatis会报以下错误:oracle
org.apache.ibatis.binding.BindingException:
Parameter 'id' not found.
Available parameters are [1, 0, param1, param2app
正确的取值方式1:#{param1},#{param2}spa
正确的取值方式1:使用命名参数方式
明确指定封装参数时map的key;@Param("id"),如:
public Employee getEmpByIdAndLastName(@Param("id")Integer id,
@Param("lastName")String lastName);
多个参数会被封装成 一个map,
key:使用@Param注解指定的值
value:参数值
使用#{指定的key}取出对应的参数值,如:${lastName}
3.POJO:
若是多个参数正好是咱们业务逻辑的数据模型,咱们就能够直接传入pojo;
#{属性名}:取出传入的pojo的属性值
4.Map:
若是多个参数不是业务模型中的数据,没有对应的pojo,不常常使用,为了方便,咱们也能够传入map
#{key}:取出map中对应的值
5.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中。
Collection:${collection[index]}
List:${list[index]}
数组:${array[index]}