当前位置: 首页 > news >正文

自己做网站推广在那个网站简历模板制作

自己做网站推广在那个网站,简历模板制作,品牌型网站有哪些,资源网站推荐几个SpringBoot Mybatis-Plus 日志带参数 1 实现代码2 测试结果 在Spring Boot中#xff0c;MyBatis插件机制通过拦截器#xff08;Interceptor#xff09;来实现。拦截器允许开发人员在执行SQL语句的各个阶段#xff08;如SQL语句创建、参数处理、结果映射等#xff09;插入自… SpringBoot Mybatis-Plus 日志带参数 1 实现代码2 测试结果 在Spring Boot中MyBatis插件机制通过拦截器Interceptor来实现。拦截器允许开发人员在执行SQL语句的各个阶段如SQL语句创建、参数处理、结果映射等插入自定义逻辑。MyBatis的拦截器主要用于增强MyBatis的功能如日志记录、性能监控、实现分页、数据权限控制、SQL日志、动态SQL生成等在SQL执行之前后提供了四个拦截点在方法执行前后进行处理支持不同场景的功能扩展。 类作用Executor用于执行增/删/改/查等数据库操作。ParameterHandler用于处理 SQL 参数。ResultSetHandler用于处理结果集。StatementHandler用于处理 SQL 语句的创建和参数化。 Signature参数说明 参数参数说明type就是指定拦截器类型(Executor, ParameterHandler, StatementHandler, ResultSetHandler)。method是拦截器类型中的方法不是自己写的方法(update, query, prepare …)。args是method中方法的入参。 Executor接口中常见的方法 方法实现原理update执行插入、更新和删除操作。query执行查询操作返回结果集。flushStatements刷新批量执行的 SQL 语句。commit提交事务。rollback回滚事务。getTransaction获取当前事务对象。close关闭执行器。isClosed检查执行器是否已关闭。clearLocalCache清空本地缓存。 Mybatis拦截器的实现原理 方法实现原理注册拦截器拦截器需要在 MyBatis 配置文件中注册通常是在 mybatis-config.xml 中配置也可以通过 Java 配置类进行注册。实现 Interceptor 接口自定义拦截器需要实现 MyBatis 的 Interceptor 接口并重写 intercept 方法。这个方法会接收一个 Invocation 对象表示被拦截的方法调用。调用链MyBatis 在执行 SQL 操作时会按照拦截器的配置顺序依次调用每个拦截器的 intercept 方法。拦截器可以选择在方法执行前后进行处理或者直接修改方法参数和返回值。 Intercepts({Signature(type Executor.class, method update, args {MappedStatement.class, Object.class}),Signature(type Executor.class, method query, args {MappedStatement.class, Object.class, RowBounds.class, ResultHandler.class}) }) public class MyInterceptor implements Interceptor {... }1 实现代码 import java.text.DateFormat; import lombok.extern.slf4j.Slf4j;import cn.hutool.core.collection.CollUtil;import java.util.Date; import java.util.List; import java.util.Locale; import java.util.Properties; import java.util.regex.Matcher;import java.sql.Connection;import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; import org.springframework.stereotype.Component;import org.apache.ibatis.executor.statement.StatementHandler; import org.apache.ibatis.mapping.BoundSql; import org.apache.ibatis.mapping.MappedStatement; import org.apache.ibatis.mapping.ParameterMapping; import org.apache.ibatis.plugin.Interceptor; import org.apache.ibatis.plugin.Intercepts; import org.apache.ibatis.plugin.Invocation; import org.apache.ibatis.plugin.Plugin; import org.apache.ibatis.plugin.Signature; import org.apache.ibatis.reflection.DefaultReflectorFactory; import org.apache.ibatis.reflection.MetaObject; import org.apache.ibatis.reflection.SystemMetaObject; import org.apache.ibatis.session.Configuration; import org.apache.ibatis.type.TypeHandlerRegistry;Slf4j Component ConditionalOnProperty(prefix mybatis-plus, name customer-log, havingValue true) Intercepts({Signature(type StatementHandler.class, method prepare, args {Connection.class, Integer.class})}) public class MybatisLogger implements Interceptor {Overridepublic Object intercept(Invocation invocation) throws Throwable {StatementHandler handler (StatementHandler) invocation.getTarget();MetaObject object MetaObject.forObject(handler,SystemMetaObject.DEFAULT_OBJECT_FACTORY,SystemMetaObject.DEFAULT_OBJECT_WRAPPER_FACTORY,new DefaultReflectorFactory());MappedStatement statement (MappedStatement) object.getValue(delegate.mappedStatement);log.info(SQL执行类: {}, statement.getId());log.info(SQL执行类型: {}, statement.getSqlCommandType().toString());BoundSql bound handler.getBoundSql();Configuration configuration statement.getConfiguration();String sql getFullSql(configuration, bound);log.info(SQL语句: {}, sql);long start System.currentTimeMillis();Object value invocation.proceed();long end System.currentTimeMillis();log.info(SQL耗时: {}, (end - start));return value;}Overridepublic Object plugin(Object target) {return Plugin.wrap(target, this);}Overridepublic void setProperties(Properties properties) {// 可以通过MyBatis配置文件或注解传递属性}public String getFullSql(Configuration conf, BoundSql bound) {Object object bound.getParameterObject();ListParameterMapping list bound.getParameterMappings();String sql bound.getSql().replaceAll([\\s], ).toLowerCase(Locale.ROOT);if (CollUtil.isNotEmpty(list) object ! null) {TypeHandlerRegistry type conf.getTypeHandlerRegistry();if (type.hasTypeHandler(object.getClass())) {sql sql.replaceFirst(\\?, Matcher.quoteReplacement(getParaValue(object)));} else {MetaObject meta conf.newMetaObject(object);for (ParameterMapping parameterMapping : list) {String name parameterMapping.getProperty();if (meta.hasGetter(name)) {Object obj meta.getValue(name);sql sql.replaceFirst(\\?, Matcher.quoteReplacement(getParaValue(obj)));} else if (bound.hasAdditionalParameter(name)) {Object obj bound.getAdditionalParameter(name);sql sql.replaceFirst(\\?, Matcher.quoteReplacement(getParaValue(obj)));} else {sql sql.replaceFirst(\\?, 缺失);}}}}return sql;}private String getParaValue(Object obj) {if (obj instanceof String) {return obj ;} else if (obj instanceof Date) {DateFormat formatter DateFormat.getDateTimeInstance(DateFormat.DEFAULT, DateFormat.DEFAULT, Locale.CHINA);return formatter.format(new Date()) ;} else {if (obj ! null) {return obj.toString();} else {return ;}}}}2 测试结果 Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession264df4aa] Creating a new SqlSession SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSessiond91483c] was not registered for synchronization because synchronization is not active JDBC Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl44d84b5a] will not be managed by Spring 2024-07-05 16:32:27.660 INFO 3264 --- [nio-8221-exec-1] com.xu.hander.MybatisLogger : SQL执行类: com.xu.view.mapper.StudentMapper.selectOne 2024-07-05 16:32:27.660 INFO 3264 --- [nio-8221-exec-1] com.xu.hander.MybatisLogger : SQL执行类型: SELECT 2024-07-05 16:32:27.660 INFO 3264 --- [nio-8221-exec-1] com.xu.hander.MybatisLogger : SQL语句: select id,create_by,create_time,create_hour,create_date,update_by,update_time,tenant_id,user_id,cus_id,page,number,is_share,time,event from student where (cus_id 3 and page 3 and event 5) order by create_time desc limit 1 2024-07-05 16:32:27.663 INFO 3264 --- [nio-8221-exec-1] com.xu.hander.MybatisLogger : SQL耗时: 3
http://www.dnsts.com.cn/news/214770.html

相关文章:

  • .net网站开发工程师qq邮箱网页版登录入口
  • 广州网站建设好做吗做挂网站
  • 公司网站制做贵阳app开发定制
  • 如何用excel来做网站后台网站人员队伍建设落后
  • 城建公司建设网站基础资料网站建设电子合同模板
  • 阿里云服务器创建网站吗免费下载app并安装
  • 网站用户互动天津市城乡建设网
  • 网站首页焦点图网站构建的基本流程
  • 如何查看网站模板网站经营性质
  • 海城百度公司 海城网站建设2019做什么类型网站
  • 成都工程建设信息网站apache网站部署
  • 橙色网站设计公司网站传图片
  • 关键词搜不到我的网站wordpress调用数据库连接
  • 河北省建设安全监督站的网站查重网站开发
  • 奎屯网站建设多媒体展厅哪家公司好
  • 从网站开发到游戏编程深圳市宽带哪个公司的好
  • 手机微信客户端网站建设网站扫码怎么做
  • 做网站备案需要多长时间北仑网站建设29gz
  • 游戏平台网站建设外包和劳务派遣哪个更好
  • 网站设计两边为什么要留白瑞诺国际公司团队介绍
  • 新乡专业做网站的公司哪家好自定义菜单WordPress
  • 网站优化检查什么是网络营销渠道中最重要的中间商
  • 淘客联盟做任务网站做网站需要参考书目书
  • 盱眙网站建设公司南京建设企业管理高层培训
  • 检察院门户网站建设做网站阳泉
  • wordpress 娱乐插件seo技术优化服务
  • wordpress做小说网站吗三丰云服务器
  • 网站部署设计网络规划设计师教程读后感
  • 响应式网站设计与实现论文郑州app开发哪家好
  • 设计师学编程能自己做网站吗重庆短视频制作公司