Spring Mybatis随记

  1. 连接池获取连接逻辑
com.zaxxer.hikari.pool.HikariPool#getConnection(long)
// 内部循环获取空闲连接,返回前检查数据库连接是否可以用
  1. Spring获取连接
    如果已经开启了事务,只要没提交事务,调用非事务的DAO执行sql也会被事务统一管理
org.springframework.jdbc.datasource.DataSourceTransactionManager#doBegin 
// 获取连接后将其设置为手动提交
  1. mybatis获取连接
org.mybatis.spring.transaction.SpringManagedTransaction#getConnection
// 一个线程里当前只有一个连接被org.springframework.transaction.support.TransactionSynchronizationManager管理
// 如果非事务的操作,或者事务已提交,该连接不会被Spring管理
org.mybatis.spring.transaction.SpringManagedTransaction#openConnection
  1. mybatis获取SqlSession
org.mybatis.spring.SqlSessionUtils#getSqlSession
// 使用Spring管理SqlSession
org.mybatis.spring.SqlSessionUtils#registerSessionHolder

mybatis通过SqlSession进行数据库操作;
spring中通过TransactionSynchronizationManager为每个线程对应的数据库连接维护了事务相关的信息

  1. 打印事务日志
<!-- hikari 日志--><logger name="com.zaxxer" level="DEBUG" additivity="false"><appender-ref ref="console"/></logger><!-- 数据库连接 --><logger name="org.springframework.jdbc" level="DEBUG" additivity="false"><appender-ref ref="console"/></logger><!--spring 事务相关--><logger name="org.springframework.transaction" level="DEBUG" additivity="false"><appender-ref ref="console"/></logger><!-- mybatis 相关--><logger name="org.mybatis.spring" level="DEBUG" additivity="false"><appender-ref ref="console"/></logger>
  1. 打印SQL
mybatis-plus:configuration:log-impl: org.apache.ibatis.logging.slf4j.Slf4jImpl
	<!-- 开启业务mapper日志 --><logger name="com.ibreeze" level="DEBUG" additivity="false"><appender-ref ref="console"/></logger>
  1. 日志过程
// Spring JDBC获取连接
o.s.jdbc.support.JdbcTransactionManager  : Acquired Connection [HikariProxyConnection@748466085 wrapping com.mysql.cj.jdbc.ConnectionImpl@402d6012] for JDBC transaction
// 连接设置为手动提交
o.s.jdbc.support.JdbcTransactionManager  : Switching JDBC Connection [HikariProxyConnection@748466085 wrapping com.mysql.cj.jdbc.ConnectionImpl@402d6012] to manual commit
o.s.jdbc.support.JdbcTransactionManager  : Participating in existing transaction
org.mybatis.spring.SqlSessionUtils       : Creating a new SqlSession
org.mybatis.spring.SqlSessionUtils       : Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@46c662f2]
c.j.b.c.m.c.MybatisPlusMetaObjectHandler : mybatis plus start insert fill ....
// myabtis.Spring
o.m.s.t.SpringManagedTransaction         : JDBC Connection [HikariProxyConnection@748466085 wrapping com.mysql.cj.jdbc.ConnectionImpl@402d6012] will be managed by Spring
// SqlSession CRUD
c.j.b.w.b.f.m.SysFormMapper2.insert      : ==>  Preparing: INSERT INTO bip_wf_form ( form_id, form_name, create_by, create_time, update_by, update_time ) VALUES ( ?, ?, ?, ?, ?, ? )
c.j.b.w.b.f.m.SysFormMapper2.insert      : ==> Parameters: 1702632127793(Long), in(String), null, 2023-12-15T17:22:07.793(LocalDateTime), null, 2023-12-15T17:22:07.844(LocalDateTime)
c.j.b.w.b.f.m.SysFormMapper2.insert      : <==    Updates: 1
// 释放SqlSession操作
org.mybatis.spring.SqlSessionUtils       : Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@46c662f2]
// 再次操作时重新获取SqlSession
org.mybatis.spring.SqlSessionUtils       : Fetched SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@46c662f2] from current transaction
com.zaxxer.hikari.pool.HikariPool        : HikariPool-1 - Pool stats (total=1, active=1, idle=0, waiting=0)
c.j.b.w.b.f.m.S.selectCount              : ==>  Preparing: SELECT COUNT( * ) FROM bip_wf_form
c.j.b.w.b.f.m.S.selectCount              : ==> Parameters: 
com.zaxxer.hikari.pool.HikariPool        : HikariPool-1 - Added connection com.mysql.cj.jdbc.ConnectionImpl@30cf72ed
com.zaxxer.hikari.pool.HikariPool        : HikariPool-1 - After adding stats (total=2, active=1, idle=1, waiting=0)
c.j.b.w.b.f.m.S.selectCount              : <==      Total: 1
org.mybatis.spring.SqlSessionUtils       : Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@46c662f2]org.mybatis.spring.SqlSessionUtils       : Transaction synchronization deregistering SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@46c662f2]
org.mybatis.spring.SqlSessionUtils       : Transaction synchronization closing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@46c662f2]
// 回滚数据库
o.s.jdbc.support.JdbcTransactionManager  : Initiating transaction rollback
o.s.jdbc.support.JdbcTransactionManager  : Rolling back JDBC transaction on Connection [HikariProxyConnection@748466085 wrapping com.mysql.cj.jdbc.ConnectionImpl@402d6012]
// 释放连接
o.s.jdbc.support.JdbcTransactionManager  : Releasing JDBC Connection [HikariProxyConnection@748466085 wrapping com.mysql.cj.jdbc.ConnectionImpl@402d6012] after transaction

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/224169.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于物理的AlGaN/GaN HEMT器件2DEG电荷密度分析模型(文献阅读)

标题&#xff1a;A Physics-Based Analytical Model for 2DEG Charge Density in AlGaN/GaN HEMT Devices (IEEE TRANSACTIONS ON ELECTRON DEVICES) 重要公式 2DEG电荷密度建模的困难源于量子阱中Ef随ns的复杂变化。此关系由给出 n s D V t h [ l n ( l e E f − E 0 V t …

Seconds_Behind_Master越来越大,主从同步延迟

问题现象 发现从库mysql_slave的参数Seconds_Behind_Master越来越大。已排除主从服务器时间不一致&#xff1b;那么主要就判断两点&#xff1a;是io thread慢还是 sql thread慢&#xff1f;先观察show slave status\G 。 判断3个参数&#xff08;参数后面的值是默认空闲时候的…

文献速递:PET-影像组学专题--PET衍生的影像组学和人工智能在乳腺癌中的应用:一篇系统综述

文献速递&#xff1a;PET-影像组学专题–PET衍生的影像组学和人工智能在乳腺癌中的应用&#xff1a;一篇系统综述 01 文献速递介绍 乳腺癌&#xff08;BC&#xff09;是目前流行度最高的恶性肿瘤&#xff0c;也是全球女性癌症相关死亡的第二大原因&#xff0c;过去十年间发病…

开个酸奶店需要投资多少钱,创业优势在哪里

作为酸奶店创业5年的创业者&#xff0c;我给大家做个详细全面的分析。让你花最少的钱开一家属于你的酸奶店&#xff01; 这几年&#xff0c;随着奶茶店的烂大街&#xff0c;酸奶产品开始展露头脚&#xff0c;受到了无数消费者的追捧。从而很多创业者也瞄准了这个市场&#xff…

智合同丨合同审查要点及注意事项

#人工智能#合同审查#合同#自然语言#知识图谱 最近有朋友留言让小智多梳理一些关于合同审查方面的内容&#xff0c;今天就合同审查要点和注意事项做一个梳理&#xff0c;其实之前也有类似文章&#xff0c;大家有空可以翻看下。 智合同采用深度学习、自然语言处理技术、知识图谱…

产品经理之Axure的元件库使用详细案例

⭐⭐ 产品经理专栏&#xff1a;产品专栏 ⭐⭐ 个人主页&#xff1a;个人主页 ​ 目录 前言 一.Axure的元件库的使用 1.1 元件介绍 1.2 基本元件的使用 1.2.1 矩形、按钮、标题的使用 1.2.2 图片及热区的使用 1.3 表单元件及表格元件的使用 1.3.1表单元件的使用 1.3.…

【Linux】进程周边004之进程的调度与切换(领略Linux系统进程调度算法的神奇)

&#x1f440;樊梓慕&#xff1a;个人主页 &#x1f3a5;个人专栏&#xff1a;《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》《实训项目》《C》《Linux》 &#x1f31d;每一个不曾起舞的日子&#xff0c;都是对生命的辜负 目录 前言 1.进程切换 2.进程调度 2.…

Infobright列存数据库原理介绍

简介 Infobright 是一个面向 OLAP 场景的开源列存数据库。比较容易找到代码的版本是 Infobright Community Edition 4.0.7&#xff0c;大概是 2006 年前后的代码。2016 年6 月&#xff0c;Infobright 决定停止开源1。由于它同时提供企业版和社区版&#xff0c;开源版本的功能相…

基于ssm大学学术交流论坛论文

摘 要 随着科学技术的飞速发展&#xff0c;各行各业都在努力与现代先进技术接轨&#xff0c;通过科技手段提高自身的优势&#xff1b;对于大学学术交流论坛当然也不能排除在外&#xff0c;随着网络技术的不断成熟&#xff0c;带动了大学学术交流论坛的发展&#xff0c;它彻底改…

C# 图解教程 第5版 —— 第18章 泛型

文章目录 18.1 什么是泛型18.2 C# 中的泛型18.3 泛型类18.3.1 声明泛型类18.3.2 创建构造类型18.3.3 创建变量和实例18.3.4 使用泛型的示例18.3.5 比较泛型和非泛型栈 18.4 类型参数的约束18.4.1 Where 子句18.4.2 约束类型和次序 18.5 泛型方法18.5.1 声明泛型方法18.5.2 调用…

go-zero开发入门之网关往rpc服务传递数据1

go-zero 的网关往 rpc 服务传递数据时&#xff0c;可以使用 headers&#xff0c;但需要注意前缀规则&#xff0c;否则会发现数据传递不过去&#xff0c;或者对方取不到数据。 go-zero 的网关对服务的调用使用了第三方库 grpcurl&#xff0c;入口函数为 InvokeRPC&#xff1a; …

Linux系统中如何开启和配置OpenGauss数据库的远程连接

文章目录 前言1. Linux 安装 openGauss2. Linux 安装cpolar3. 创建openGauss主节点端口号公网地址4. 远程连接openGauss5. 固定连接TCP公网地址6. 固定地址连接测试7. 结语 前言 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍…

基于Maven构建OSGI应用(Maven和OSGI结合)

基于Maven构建OSGI应用。 使用Maven来构建项目&#xff0c;包括项目的创建、子模块buldle的创建等。使用OSGI来实现动态模块化管理&#xff0c;实现模块的热插拔效果&#xff08;即插即用&#xff09;。 创建一个Maven项目&#xff1a;helloworld&#xff0c;并在该项目下创建…

selenium/webdriver运行原理与机制

最近在看一些底层的东西。driver翻译过来是驱动&#xff0c;司机的意思。如果将webdriver比做成司机&#xff0c;竟然非常恰当。 我们可以把WebDriver驱动浏览器类比成出租车司机开出租车。在开出租车时有三个角色&#xff1a; 乘客&#xff1a;他/她告诉出租车司机去哪里&…

springboot_tomcat开启access log日志,监控打印每个请求地址和响应时间

springboot_tomcat开启access log日志&#xff0c;监控打印每个请求地址和响应时间 一、前言二、环境三、配置对应的对象信息四、AccessLog配置默认值及说明五、配置实例六、pattern参数组成说明七、常用的pattern配置7.1 pattern默认值7.2 默认配置说明7.3 打印请求、响应中co…

解决因找不到qt5core.dll文件而导致无法执行代码问题

Qt5core.dll是Qt5框架的核心模块&#xff0c;用于提供基本的Qt功能。如果在代码执行过程中找不到qt5core.dll&#xff0c;可能导致相关功能无法正常使用。以下是五种详细解决方法、qt5core.dll文件详细介绍以及丢失原因。 一、qt5core.dll文件详细介绍 文件名称&#xff1a;q…

白杨SEO:从董宇辉事件聊聊个人IP这个事,企业为什么要重视个人IP?

董宇辉事件是指东方甄选因主播董宇辉的小作文到底由谁写的风波&#xff0c;具体详情可以网上搜搜&#xff0c;最近是热搜。下图1产生原因&#xff0c;下图2董宇辉回应截图。 白杨SEO说一下&#xff0c;这里不关注谁对谁错。我想说的是&#xff0c;一是现在个人IP非常重要&…

《微信小程序开发从入门到实战》学习五十一

4.5 实现投票小程序服务端功能 4.5.4 获取我的投票信息 最后实现“我的”投票页面。该页面pages/myVote/myVote.js还有一个todo,获取用参与的所有投票的列表。这个功能需要用到用户的openid&#xff0c;因此也需要使用云函数来实现。 新建myVoteList云函数。完成代码将其上传…

C语言结构体小项目之通讯录代码实现+代码分析

一、思路 1.文件 这里由于通讯录实现代码较长&#xff0c;因此分三个文件进行&#xff0c;contact.c用于实现通讯录主体代码&#xff0c;声明各项头文件用contact.h实现&#xff0c;测试用test.c 二.功能 增加联系人删除联系人修改联系人查找指定联系人排序显示通讯录的信息…

Mac 打不开github解决方案

序言 github 时有打不开的情况&#xff0c;为此很是烦恼&#xff0c;这里分享一下如何解决这种问题&#xff0c;其实问题的本质是在访问github网页时无法通过github.com的二级域名进行动态域名解析。 解决方案 手动配置静态文件hosts&#xff0c;将该域名和IP的映射关系添加…