MyBatis快速入门——第六章、MyBatis拦截器接口(二)

简介: MyBatis快速入门——第六章、MyBatis拦截器接口(二)

1、修改返回值

<?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.item.mapper.ProductMapper">
    <select id="GetInfo" resultType="java.util.Map">
        select * from product
        <if test="productName!=null or productType!=null or productColor!=null ">
            where 1=1
        </if>
        <!-- 模糊查询 -->
        <if test="productName!=null">
            and productName like "%${productName}%"
        </if>
        <!-- 类型筛选 -->
        <if test="productType!=null">
            and productType="${productType}"
        </if>
        <!-- 颜色筛选 -->
        <if test="productColor!=null">
            and productColor="${productColor}"
        </if>
    </select>
    <update id="UpdateById">
        update product set productTitle = "${productTitle}" where id=#{id}
    </update>
</mapper>

2、创建【CamelHumpInterceptor】 文件

package com.item.interceptor;
import org.apache.ibatis.executor.Executor;
import org.apache.ibatis.mapping.MappedStatement;
import org.apache.ibatis.plugin.*;
import java.lang.reflect.Method;
import java.util.Properties;
@Intercepts({
        @Signature(
                type = Executor.class,//指定要拦截的接口
                method = "update",//设置拦截接口中的方法名
                args = {MappedStatement.class,Object.class}//设置拦截方法的参数类型数组
        )
})
public class MyBatisInterceptor implements Interceptor {
    /**
     * 获取被拦截器拦截对象的相关信息
     * @param invocation
     * @return
     * @throws Throwable
     */
    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        //拦截目标
        Object target = invocation.getTarget();
        System.out.println("目标:"+target);
        //获取被拦截对象执行的方法
        Method method = invocation.getMethod();
        System.out.println("方法:"+method.getName());
        //获取执行目标的中参数
        Object[] args = invocation.getArgs();
        for (Object o : args) {
            System.out.println("参数:"+o);
        }
        Object proceed = invocation.proceed();
        System.out.println("继续:"+proceed);
        return proceed;
    }
    /**
     * 获取当前拦截对象
     * @param target
     * @return
     */
    @Override
    public Object plugin(Object target) {
        System.out.println("当前拦截对象"+target);
        return Plugin.wrap(target,this);
    }
    /**
     * 获取拦截器插件中的参数值
     * @param properties
     */
    @Override
    public void setProperties(Properties properties) {
        System.out.println("参数0:"+properties.get("prop0"));
        System.out.println("参数1:"+properties.get("prop1"));
    }
}

执行返回效果:

image.png

相关文章
|
4月前
|
SQL Java 数据库连接
Mybatis之Mybatis简介、搭建Mybatis相关步骤(开发环境、maven、核心配置文件、mapper接口、映射文件、junit测试、log4j日志)
【1月更文挑战第2天】 MyBatis最初是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Software Foundation迁移到了Google Code。随着开发团队转投Google Code旗下,iBatis3.x正式更名为MyBatis。代码于2013年11月迁移到Github iBatis一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBatis提供的持久层框架包括SQL Maps和Data Access Objects(DAO)
204 3
Mybatis之Mybatis简介、搭建Mybatis相关步骤(开发环境、maven、核心配置文件、mapper接口、映射文件、junit测试、log4j日志)
|
4月前
|
测试技术 数据库
深入探索MyBatis-Plus中Service接口的lambdaUpdate用法及示例
深入探索MyBatis-Plus中Service接口的lambdaUpdate用法及示例
262 0
|
11天前
|
Java 数据库连接 数据库
MybatisPlus中IService接口有什么用?
MybatisPlus中IService接口有什么用?
|
11天前
|
Java 数据库连接 mybatis
MyBatis中Mapper接口和dao区别是什么?
MyBatis中Mapper接口和dao区别是什么?
|
23天前
|
SQL Java 数据库连接
MyBatis之魂:探索核心接口SqlSession的神秘力量
MyBatis之魂:探索核心接口SqlSession的神秘力量
26 3
MyBatis之魂:探索核心接口SqlSession的神秘力量
|
2月前
|
XML SQL Java
Mybatis接口Mapper内的方法为啥不能重载吗
Mybatis接口Mapper内的方法为啥不能重载吗
20 0
|
2月前
Mybatis+mysql动态分页查询数据案例——房屋信息的接口(IHouseDao)
Mybatis+mysql动态分页查询数据案例——房屋信息的接口(IHouseDao)
13 1
|
2月前
ssm(Spring+Spring mvc+mybatis)Dao接口——IDeptDao
ssm(Spring+Spring mvc+mybatis)Dao接口——IDeptDao
9 0
|
2月前
|
Java 数据库连接 mybatis
mybatis简单案例源码详细【注释全面】——Dao层接口(UserMapper.java)
mybatis简单案例源码详细【注释全面】——Dao层接口(UserMapper.java)
7 0