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参数传递和取值详情:

单个参数:Mybatis不会做特殊处理, #{参数名/任意名}:取出参数值。
    
多个参数:mybatis会做特殊处理。
    1.多个参数会被封装成 一个map,
        封装:

            key:paramName1...paramNameN,或者参数的索引也可以
            value:传入的参数值
         取值:

            #{paramName}就是从map中获取指定的key的值;
    
    操作:
        方法:public Employee getEmpByIdAndLastName(Integer id,String lastName);
        取值:#{id},#{lastName}

    2.形参了表有多个参数

        public Employee getEmpByIdAndLastName(Integer id,String lastName);

        错误的取值方式:#{id},#{lastName}

        Mybatis会报如下错误:

            org.apache.ibatis.binding.BindingException: 
            Parameter 'id' not found. 
            Available parameters are [1, 0, param1, param2

        正确的取值方式1:#{param1},#{param2}

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

转载于:https://my.oschina.net/u/3049601/blog/1610163

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值