基于maven管理的项目中spring+mybatis配置数据源读取不到properties属性文件的问题
2015-05-14 23:38
441 查看
<bean id="tomcatJdbcDataSourceFactory" class="com.qunar.db.resource.impl.TomcatJdbcDataSourceFactory"/>
<bean id="dataSource" class="com.qunar.db.resource.RWDelegatorDataSource">
<constructor-arg index="0" type="java.lang.String" value="${dictDataSource.jdbc.usernameSpace}"/>
<constructor-arg index="1" type="java.lang.String" value="${dictDataSource.jdbc.username}"/>
<constructor-arg index="2" type="java.lang.String" value="${dictDataSource.jdbc.password}"/>
<constructor-arg index="3" type="java.lang.String" value="${dictDataSource.jdbc.db_name}"/>
<constructor-arg index="4" type="int" value="20"/>
<constructor-arg index="5" type="int" value="50"/>
<constructor-arg index="6" type="java.lang.String" value="?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true"/>
<constructor-arg index="7" type="boolean" value="true"/>
<constructor-arg index="8" ref="tomcatJdbcDataSourceFactory"/>
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="configLocation" value="classpath:mybatis-config.xml"/>
<property name="mapperLocations" value="classpath*:com.anly.portal.*.mapper/*Mapper.xml" />
</bean>
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.anly.portal.*.mapper"/>
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
此时,启动会报异常,${jdbc.driver}这样的表达式获取不到properties里面的值,因为MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了,解决的办法如下:
修改为
<bean id="tomcatJdbcDataSourceFactory" class="com.qunar.db.resource.impl.TomcatJdbcDataSourceFactory"/>
<bean id="dataSource" class="com.qunar.db.resource.RWDelegatorDataSource">
<constructor-arg index="0" type="java.lang.String" value="${dictDataSource.jdbc.usernameSpace}"/>
<constructor-arg index="1" type="java.lang.String" value="${dictDataSource.jdbc.username}"/>
<constructor-arg index="2" type="java.lang.String" value="${dictDataSource.jdbc.password}"/>
<constructor-arg index="3" type="java.lang.String" value="${dictDataSource.jdbc.db_name}"/>
<constructor-arg index="4" type="int" value="20"/>
<constructor-arg index="5" type="int" value="50"/>
<constructor-arg index="6" type="java.lang.String" value="?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true"/>
<constructor-arg index="7" type="boolean" value="true"/>
<constructor-arg index="8" ref="tomcatJdbcDataSourceFactory"/>
</bean>
<bean class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="mapperLocations" value="classpath:mappers/*.xml"/>
</bean>
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.qunar.flight.interb2b.airport.dict.dao" />
<property name="sqlSessionFactoryBeanName" value="sessionFactory" />
</bean>
原理:使用sqlSessionFactoryBeanName注入,不会立即初始化sqlSessionFactory, 所以不会引发提前初始化问题,同时还应注意在配置org.mybatis.spring.SqlSessionFactoryBean
这个Bean时,id不能为sqlSessionFactory,如果为这样的话会导致MapperScannerConigurer在bean定义加载时,加载PropertyPlaceholderConfigurer还没来得及替换定义中的变量
<bean id="dataSource" class="com.qunar.db.resource.RWDelegatorDataSource">
<constructor-arg index="0" type="java.lang.String" value="${dictDataSource.jdbc.usernameSpace}"/>
<constructor-arg index="1" type="java.lang.String" value="${dictDataSource.jdbc.username}"/>
<constructor-arg index="2" type="java.lang.String" value="${dictDataSource.jdbc.password}"/>
<constructor-arg index="3" type="java.lang.String" value="${dictDataSource.jdbc.db_name}"/>
<constructor-arg index="4" type="int" value="20"/>
<constructor-arg index="5" type="int" value="50"/>
<constructor-arg index="6" type="java.lang.String" value="?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true"/>
<constructor-arg index="7" type="boolean" value="true"/>
<constructor-arg index="8" ref="tomcatJdbcDataSourceFactory"/>
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="configLocation" value="classpath:mybatis-config.xml"/>
<property name="mapperLocations" value="classpath*:com.anly.portal.*.mapper/*Mapper.xml" />
</bean>
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.anly.portal.*.mapper"/>
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
此时,启动会报异常,${jdbc.driver}这样的表达式获取不到properties里面的值,因为MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了,解决的办法如下:
修改为
<bean id="tomcatJdbcDataSourceFactory" class="com.qunar.db.resource.impl.TomcatJdbcDataSourceFactory"/>
<bean id="dataSource" class="com.qunar.db.resource.RWDelegatorDataSource">
<constructor-arg index="0" type="java.lang.String" value="${dictDataSource.jdbc.usernameSpace}"/>
<constructor-arg index="1" type="java.lang.String" value="${dictDataSource.jdbc.username}"/>
<constructor-arg index="2" type="java.lang.String" value="${dictDataSource.jdbc.password}"/>
<constructor-arg index="3" type="java.lang.String" value="${dictDataSource.jdbc.db_name}"/>
<constructor-arg index="4" type="int" value="20"/>
<constructor-arg index="5" type="int" value="50"/>
<constructor-arg index="6" type="java.lang.String" value="?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true"/>
<constructor-arg index="7" type="boolean" value="true"/>
<constructor-arg index="8" ref="tomcatJdbcDataSourceFactory"/>
</bean>
<bean class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="mapperLocations" value="classpath:mappers/*.xml"/>
</bean>
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.qunar.flight.interb2b.airport.dict.dao" />
<property name="sqlSessionFactoryBeanName" value="sessionFactory" />
</bean>
原理:使用sqlSessionFactoryBeanName注入,不会立即初始化sqlSessionFactory, 所以不会引发提前初始化问题,同时还应注意在配置org.mybatis.spring.SqlSessionFactoryBean
这个Bean时,id不能为sqlSessionFactory,如果为这样的话会导致MapperScannerConigurer在bean定义加载时,加载PropertyPlaceholderConfigurer还没来得及替换定义中的变量
相关文章推荐
- spring中mybatis配置数据源读取不到properties属性文件的问题
- mybatis3.0x升级整合spring问题(读取不到properties文件属性)
- 解决spring-boot项目中无法读取yml配置文件属性问题
- IDEA spring的xml配置文件加载不到properties属性问题
- 解决eclipse创建spring boot项目加载不到application.properties配置文件的问题
- IDEA spring的xml配置文件加载不到properties属性问题
- 解决Spring配置文件无法读取properties属性问题
- spring+mybatis 数据源读取不到配置文件的值
- Spring配置文件中读取properties文件的属性
- spring管理属性配置文件properties——使用PropertiesFactoryBean
- spring管理属性配置文件properties——使用PropertyPlaceholderConfigurer
- 关于Spring与mybatis整合无法读取配置文件的问题
- myeclipse部署maven项目到tomcat,src/main/resources里面配置文件部署不到webapp下classes的问题
- SpringMVC + mybatis 无法读取JAR包中的XML配置文件问题
- springmvc+mybatis+maven项目集成的时候遇到一个问题,项目搭起来以后,http请求怎么都进不到controller中,页面直接返回404错误,控制台没有报任何错误,请大神帮我看看
- 解决整合spring和mybatis后数据源配置文件读取错误,错误提示数据库用户名密码错误。
- Spring学习总结(20)——Spring加载多个项目properties配置文件问题解决
- Spring学习总结(20)——Spring加载多个项目properties配置文件问题解决
- SpringMVC + mybatis 无法读取JAR包中的XML配置文件问题
- [置顶] 关于Idea基于maven创建springMvc项目中配置文件自动扫描找不到base-package问题