场景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