Mybatis 映射文件配置

<?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, param2
app

        正确的取值方式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]}

相关文章
相关标签/搜索