spring+mybatis 注入properties文件中属性失败导致datasource加载失败的原因和解决
Posted 当以乐
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了spring+mybatis 注入properties文件中属性失败导致datasource加载失败的原因和解决相关的知识,希望对你有一定的参考价值。
报错
HTTP Status 500 - Request processing failed; nested exception is org.springframework.transaction.CannotCreateTransactionException: Could not open JDBC Connection for transaction; nested exception is java.sql.SQLException: $jdbc.driver
相关配置信息
<!-- 加载配置文件 -->
<context:property-placeholder location="classpath:config/config.properties"/>
<!-- 数据源 -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="url" value="$jdbc.url" />
<property name="username" value="$jdbc.username" />
<property name="password" value="$jdbc.password" />
<property name="driverClassName" value="$jdbc.driver" />
<!-- 配置初始化大小、最小、最大 -->
<!-- 通常来说,只需要修改initialSize、minIdle、maxActive -->
<property name="initialSize" value="1" />
<property name="minIdle" value="1" />
<property name="maxActive" value="20" />
<!--对于长时间不使用的连接强制关闭 -->
<property name="removeAbandoned" value="true" />
<!--超过指定时间的空闲连接 -->
<property name="removeAbandonedTimeout" value="1800" />
<!-- 配置获取连接等待超时的时间 -->
<property name="maxWait" value="60000" />
<!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
<property name="minEvictableIdleTimeMillis" value="300000" />
<!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
<property name="timeBetweenEvictionRunsMillis" value="3000" />
<property name="validationQuery" value="SELECT 'x'" />
<property name="testWhileIdle" value="true" />
<property name="testOnBorrow" value="false" />
<property name="testOnReturn" value="false" />
<property name="poolPreparedStatements" value="true" />
<property name="maxPoolPreparedStatementPerConnectionSize"
value="20" />
<!-- 解密密码必须要配置的项 -->
<property name="filters" value="config" />
<property name="connectionProperties" value="config.decrypt=false" />
</bean>
<!-- sqlsessionfactory -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="configLocation" value="classpath:mybatis/sqlMapConfig.xml"></property>
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- mapper代理配置 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.lexiang.main.mapper.orm" />
<property name="sqlSessionFactory" ref="sqlSessionFactory" />
</bean>
分析:
因为我配置了一个定时任务,而访问定时任务是可以启动并且能够读取到properties中的配置信息的
原因是在spring进行属性注入之前datasource就已经进行了初始化了,进而导致
java.sql.SQLException: $jdbc.driver
因为你使用的在未注入前本来就是 这个字符串
经过我一番查找(百度)发现仅仅需要对mybatis的扫描器做一些改动就可以了
改动如下
<!-- mapper代理配置 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.lexiang.main.mapper.orm" />
<!-- 这里不能使用的配置 name=sqlSessionFactory 这样子会导致 数据源中spring注入项还未注入就初始化了数据源-->
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
</bean>
这样就可以完美解决该问题了.
另外mark一下 spring注入properties文件的另外一个中方式;
<bean id="pc"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>classpath:config/config.properties</value>
</list>
</property>
</bean>
以上是关于spring+mybatis 注入properties文件中属性失败导致datasource加载失败的原因和解决的主要内容,如果未能解决你的问题,请参考以下文章
springboot 整合 mybatis dao一直自动注入失败
Spring整合Mybatis解决 Property 'sqlSessionFactory' or 'sqlSessionTemplate' are required(
spring整合mybatis遇到的bug java.lang.IllegalArgumentException: Property 'sqlSessionFactory' or &