在使用spring+mybatis时会出现Cannot load JDBC driver class ${jdbc.driverClassName}之类的出错。
原因是在spring里使用org.mybatis.spring.mapper.MapperScannerConfigurer 进行自动扫描的时候,设置了sqlSessionFactory 的话,可能会导致PropertyPlaceholderConfigurer失效,也就是用${jdbc.username}这样之类的表达式,将无法获取到properties文件里的内容。 导致这一原因是因为,MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了。 但如果不设置sqlSessionFactory 属性的话,就必须要保证sessionFactory在spring中名称一定要是sqlSessionFactory ,否则就无法自动注入。又或者直接定义 MapperFactoryBean ,再或者放弃自动代理接口方式。
解决方案:将
<property name="sqlSessionFactory" ref="ysSqlSessionFactory"></property>
改成<property name="sqlSessionFactoryBeanName" value="ysSqlSessionFactory" />
转载:http://songjianyong.iteye.com/blog/1663170
ps:在项目过程中还遇到mybatis返回的map值中出现重复值的现象,解决方案是换了高版本的mybatis jar包就可以了。