异常信息:java.lang.ClassNotFoundException: ${jdbc.driverClass}
原因:在spring头文件中配置了default-autowire="byName" 同时使用了sqlSessionFactory。
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="configLocation" value="classpath:config/xml/sqlMapConfig.xml"></property>
<property name="dataSource" ref="dataSource"></property>
</bean>
<bean id="userMapper" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.oskyhg.*.mapper"></property>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
</bean>
两种解决方法:
(2)或者是去掉头文件中 的default-autowire="byName" ,关闭全局的自动装配
根本原因:不能使用sqlSessionFactory的原因(网上摘抄)在spring里使用org.mybatis.spring.mapper.MapperScannerConfigurer进行自动扫描的时候,设置了sqlSessionFactory 的话,可能会导致PropertyPlaceholderConfigurer失效,
也就是用${jdbc.username}这样之类的表达式,将无法获取到properties文件里的内容。 导致这一原因是因为,MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,
这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了。 但如果不设置sqlSessionFactory 属性的话,就必须要保证sessionFactory在spring中名称一定要是sqlSessionFactory ,否则就无法自动注入。
又或者直接定义 MapperFactoryBean ,再或者放弃自动代理接口方式。