SqlSession was not registered for synchronization because synchronization is not active事务开启失败

场景1

在这里插入图片描述
大体是说事务没激活,我在在开启事务钱需要配置事务的一些条件这配置有:

  • xml配置
  • 基于注解配置

这讲解xml配置在spring-mybatis.xml或有时是在spring-service.xml其实这后面service.xml也可以合并到mybatis里面添加:

<tx:annotation-driven />

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context.xsd
    http://www.springframework.org/schema/tx
    http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd">
    <!-- 扫描service包下所有使用注解的类型 -->
    <context:component-scan base-package="com.imooc.service" />
    <!-- 配置基于注解的声明式事务 开启事务 -->
    <tx:annotation-driven />
    <!-- 配置事务管理器 -->
    <bean id="transactionManager"
          class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <!-- 注入数据库连接池 -->
        <property name="dataSource" ref="dataSource" />
    </bean>
</beans>
 

其实还在在service层里依赖注入进去@Transactional,很多人忘记来这,以为在xml里配置了就可以了。

 
/**
 * @author 江河
 * @date 2019-06-06 17:17
 */
@Transactional
@Service
public class AreaServiceImpl implements AreaService {
 
  @Autowired
  private AreaDao areaDao;
  @Override
  public List<Area> getAreaList() {
    return areaDao.queryArea();
  }
}

最后运行成功如下:
在这里插入图片描述

场景2

springboot + mybatis plus + druid进行数据库交互,出现以下提示:

Creating a new SqlSession
SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@77a86d01] was not registered for synchronization because synchronization is not active
JDBC Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@548fc58e] will not be managed by Spring

问题一、为什么每次都Creating a new SqlSession,会不会影响性能?

那个是信息,就是在一个数据库连接上,启动事务,创建一个对象来管理事务,就是在数据库连接上发出transaction.start,对象来记录相关信息。对性能影响很少

问题二、明明配置了事务,确提示事务没有交给spring管理,求解

是连接不是spring管理的(应该是应用服务器上建立的),事务还是spring管理。也是正常的

场景3

错误:was not registered for synchronization because synchronization is not active

解决思路:

1)对应的sql中出现了ParamterType对应的实体类中缺少的字段。

比如:if标签中,对name是否为空进行了判断。但是实体类中根本没有name变量,那么就会出现此错误。

2)此思路是网搜的。实体类中使用的不是包装类,而是基本数据类型。

3)是否在不该加limit 的sql中加了limit

  • 4
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: 这个错误提示意思是 "sqlsession未被注册为同步操作,因为同步操作未激活"。 在Java应用程序中,当需要使用事务(Transaction)管理器来确保数据库操作的原子性时,会启用同步操作(Synchronization)。但是,如果没有启用同步操作,就会出现这个错误。 要解决这个问题,你需要在应用程序中启用同步操作。你可以使用Spring框架来管理事务,并在配置文件中设置事务管理器的相关属性来启用同步操作。具体的做法可以参考Spring的官方文档。 ### 回答2: 当我们使用MyBatis进行数据库操作的时候,会发现在一些情况下会出现“sqlsession was not registered for synchronization because synchronization is not active”的错误信息。这个错误信息其实是一个告警(warning),并没有影响程序正常运行,但如果在开发调试的过程中,这个错误信息会影响我们的开发效率与调试难度,因此需要进一步了解这个错误信息。 错误信息的意思是“sqlSession没有注册同步,因为同步没有激活”。那么什么是同步(synchronization)呢?在MyBatis中,同步指的是和Spring框架的事务管理进行整合,也就是说,MyBatis和Spring进行了整合后,可以保证在一个事务内的所有数据库操作都能够进行同步管理,从而保证事务的原子性、一致性和隔离性。如果MyBatis没有和Spring进行整合,那么同步就没有被激活,就会出现这个错误信息。 为了解决这个问题,我们需要在配置文件(比如applicationContext.xml)中添加如下的配置项: ``` <bean id=”sqlSession” class=”org.mybatis.spring.SqlSessionFactoryBean”> <property name=”dataSource” ref=”dataSource” /> <property name=”configLocation” value=”classpath:mybatis-config.xml” /> </bean> ``` 这个配置将MyBatis的SqlSessionFactoryBean注册到Spring的容器里面,对于整合MyBatis和Spring的程序来说,基本都会有这个配置项。这个配置项中,我们需要将数据源(dataSource)和配置文件(mybatis-config.xml)配置进去。这样,当我们需要使用SqlSession进行数据库操作的时候,就不再会出现“sqlsession was not registered for synchronization because synchronization is not active”这个错误信息了。 ### 回答3: 这个问题出现在使用Spring框架的时候,通常是由于未开启事务管理导致的。 在Spring中,我们可以通过使用@Transactional注解来开启事务管理。当开启事务管理后,Spring会自动使用AOP技术截取方法调用,来控制事务的提交或回滚。 当我们使用MyBatis框架进行数据操作的时候,MyBatis的SqlSession对象是非线程安全的,也就是说,在多线程环境下会出现并发问题。因此,我们通常需要将SqlSession对象绑定到当前线程中,以保证数据的正确性和可靠性。这个绑定过程是由Spring框架完成的。当我们使用 @Transactional 注解开启事务管理的时候,Spring会为当前线程绑定一个SqlSession对象,并在事务结束时自动将其释放。 然而,在某些情况下,我们可能会遇到“sqlsession was not registered for synchronization because synchronization is not active”的错误。这种情况通常出现在我们手动管理事务的时候,没有开启事务同步。 开启事务同步可以让Spring将SqlSession对象注册到当前事务中,以保证这个对象会在事务提交或回滚时被自动释放。我们可以在Spring的配置文件中添加<tx:annotation-driven/>标签来开启事务同步。这个标签的作用就是为@Transactional注解自动创建一个事务管理器,并将其绑定到当前线程中。 如果我们不希望使用<tx:annotation-driven/>这个标签,在代码中手动管理事务,也可以通过编写自定义的事务管理器来实现事务同步。在这个事务管理器中,我们需要手动将SqlSession对象注册到当前事务中,并在事务提交或回滚时进行释放。 总之,解决“sqlsession was not registered for synchronization because synchronization is not active”错误的方法就是开启事务同步,让Spring自动管理SqlSession对象的绑定和释放。不同的项目可能有不同的配置方法,但是掌握了原理之后,我们可以根据实际情况来选择最适合自己的方式来解决这个问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

凌兮~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值