mybatis拦截器修改sql_javaweb拦截器是什么

mybatis拦截器修改sql_javaweb拦截器是什么/***Copyright2009-2016theoriginalauthororauthors.**LicensedundertheApacheLicense,Version2.0(the”License”);*youmaynotusethisfileexceptincompliancewiththeLicense.*…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

/*** Copyright 2009-2016 the original author or authors.

*

* Licensed under the Apache License, Version 2.0 (the “License”);

* you may not use this file except in compliance with the License.

* You may obtain a copy of the License at

*

*http://www.apache.org/licenses/LICENSE-2.0*

* Unless required by applicable law or agreed to in writing, software

* distributed under the License is distributed on an “AS IS” BASIS,

* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.

* See the License for the specific language governing permissions and

* limitations under the License.*/

packageorg.apache.ibatis.executor.statement;importjava.sql.Connection;importjava.sql.SQLException;importjava.sql.Statement;importorg.apache.ibatis.executor.ErrorContext;importorg.apache.ibatis.executor.Executor;importorg.apache.ibatis.executor.ExecutorException;importorg.apache.ibatis.executor.keygen.KeyGenerator;importorg.apache.ibatis.executor.parameter.ParameterHandler;importorg.apache.ibatis.executor.resultset.ResultSetHandler;importorg.apache.ibatis.mapping.BoundSql;importorg.apache.ibatis.mapping.MappedStatement;importorg.apache.ibatis.reflection.factory.ObjectFactory;importorg.apache.ibatis.session.Configuration;importorg.apache.ibatis.session.ResultHandler;importorg.apache.ibatis.session.RowBounds;importorg.apache.ibatis.type.TypeHandlerRegistry;/***@authorClinton Begin*/

public abstract class BaseStatementHandler implementsStatementHandler {protected finalConfiguration configuration;protected finalObjectFactory objectFactory;protected finalTypeHandlerRegistry typeHandlerRegistry;protected finalResultSetHandler resultSetHandler;protected finalParameterHandler parameterHandler;protected finalExecutor executor;protected finalMappedStatement mappedStatement;protected finalRowBounds rowBounds;protectedBoundSql boundSql;protectedBaseStatementHandler(Executor executor, MappedStatement mappedStatement, Object parameterObject, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql) {this.configuration =mappedStatement.getConfiguration();this.executor =executor;this.mappedStatement =mappedStatement;this.rowBounds =rowBounds;this.typeHandlerRegistry =configuration.getTypeHandlerRegistry();this.objectFactory =configuration.getObjectFactory();if (boundSql == null) { //issue #435, get the key before calculating the statement

generateKeys(parameterObject);

boundSql=mappedStatement.getBoundSql(parameterObject);

}this.boundSql =boundSql;this.parameterHandler =configuration.newParameterHandler(mappedStatement, parameterObject, boundSql);this.resultSetHandler =configuration.newResultSetHandler(executor, mappedStatement, rowBounds, parameterHandler, resultHandler, boundSql);

}

@OverridepublicBoundSql getBoundSql() {returnboundSql;

}

@OverridepublicParameterHandler getParameterHandler() {returnparameterHandler;

}

@Overridepublic Statement prepare(Connection connection, Integer transactionTimeout) throwsSQLException {

ErrorContext.instance().sql(boundSql.getSql());

Statement statement= null;try{

statement=instantiateStatement(connection);

setStatementTimeout(statement, transactionTimeout);

setFetchSize(statement);returnstatement;

}catch(SQLException e) {

closeStatement(statement);throwe;

}catch(Exception e) {

closeStatement(statement);throw new ExecutorException(“Error preparing statement. Cause: ” +e, e);

}

}protected abstract Statement instantiateStatement(Connection connection) throwsSQLException;protected void setStatementTimeout(Statement stmt, Integer transactionTimeout) throwsSQLException {

Integer queryTimeout= null;if (mappedStatement.getTimeout() != null) {

queryTimeout=mappedStatement.getTimeout();

}else if (configuration.getDefaultStatementTimeout() != null) {

queryTimeout=configuration.getDefaultStatementTimeout();

}if (queryTimeout != null) {

stmt.setQueryTimeout(queryTimeout);

}

StatementUtil.applyTransactionTimeout(stmt, queryTimeout, transactionTimeout);

}protected void setFetchSize(Statement stmt) throwsSQLException {

Integer fetchSize=mappedStatement.getFetchSize();if (fetchSize != null) {

stmt.setFetchSize(fetchSize);return;

}

Integer defaultFetchSize=configuration.getDefaultFetchSize();if (defaultFetchSize != null) {

stmt.setFetchSize(defaultFetchSize);

}

}protected voidcloseStatement(Statement statement) {try{if (statement != null) {

statement.close();

}

}catch(SQLException e) {//ignore

}

}protected voidgenerateKeys(Object parameter) {

KeyGenerator keyGenerator=mappedStatement.getKeyGenerator();

ErrorContext.instance().store();

keyGenerator.processBefore(executor, mappedStatement,null, parameter);

ErrorContext.instance().recall();

}

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/195780.html原文链接:https://javaforall.net

(1)
上一篇 2025年10月10日 下午4:15
下一篇 2025年10月10日 下午4:43


相关推荐

  • 2025 AI Agent (多智能体)平台设计和技术实现指南

    2025 AI Agent (多智能体)平台设计和技术实现指南

    2026年3月16日
    2
  • php+mysql动态网站开发案例课堂_用php写一个网页页面

    php+mysql动态网站开发案例课堂_用php写一个网页页面在这篇文章中,我尽量用最浅显易懂的语言来说明使用PHP,MySQL制作一个动态网站的基本技术。阅读本文需要简单的HTML基础知识和(任一编程语言的)编程基础知识(例如变量、值、循环、语句块的

    2022年8月6日
    7
  • 可视化报表开发_可视化数据报表

    可视化报表开发_可视化数据报表当今时代,传统的报表工具已经很难满足人们对于数据可视化的期望了,而大数据处理工具却可以为人们提供了更多的选择。微金时代的RDP报表工具操作简便,可直接上手使用,无需编码,就可以制作各种复杂、炫酷的报表。RDP报表工具表格式报表功能和亮点根据中国特色的报表需求,研发出的轻量级的企业级Web报表工具。仅需简单拖拽式配置,即可制作出各种复杂、炫酷的报表。支持中国式复杂报表的处理,例如:Excel清单报表、交叉报表、分组报表、多源分片式报表、分块报表、表单报表、图形报表、回写报表、假设分析报表、二次.

    2022年10月2日
    7
  • but六种用法_比较级的用法和句型

    but六种用法_比较级的用法和句型1.EXPLAIN简介使用EXPLAIN关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理你的SQL语句的。分析你的查询语句或是表结构的性能瓶颈。➤通过EXPLAIN,我们可以分析出以下结果:表的读取顺序数据读取操作的操作类型哪些索引可以使用哪些索引被实际使用表之间的引用每张表有多少行被优化器查询➤使用方式如下:EXPLAIN+SQL语…

    2022年10月18日
    4
  • Hunyuan-MT-7B保姆级教程:从部署到调用全流程解析

    Hunyuan-MT-7B保姆级教程:从部署到调用全流程解析

    2026年3月12日
    1
  • 关于dos启动的一些知识

    关于dos启动的一些知识       最近装一个linux版本,就要用到dos,找来找去,忙乎了半天,又是缺文件,又是改配置。发现,一直用dos,但是还没有好好研究它。要研究dos,得从它的启动信息开始。。。。   一、DOS启动过程:开机->IO.SYS->MSDOS.SYS->CONFIG.SYS->COMMAND.COM->AUTOEXEC.BAT一般来说需要修改的是MSDOS.SYS、C

    2022年7月26日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号