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 &

Spring3中用注解直接注入properties中的值

spring是怎样管理mybatis的及注入mybatis mapper bean的

mybatis与spring整合时读取properties问题的解决