Spring的Dao单元测试及运行遇到的Could not load driverClass ${jdbc.driverClass}问题解决

一、关于Dao的测试

对于Dao层编写结束后,应该立即对该层的各个数据库方法进行测试,而不是等把所有的业务逻辑写完,再进行全面测试,如果是这样,那么结果会非常痛苦,也会给其他人埋下很多坑。养成习惯很重要。

二、Dao单元测试具体步骤:

(1)、maven工程,引入相关jar包,若不是maven工程,下载相关jar包:
这里写图片描述
(2)、编写相关的test代码:
这里写图片描述
这里写图片描述

三、运行遇到的关于Could not load driverClass ${jdbc.driverClass}问题

(1)、问题:
这里写图片描述
(2)、解决办法:
第一种:
将applicationContext.xml(Spring配置文件)中的

  <property name="sqlSessionFactory" ref="sqlSessionFactory"/>

改成

        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>

记住ref要改成value
原因分析:是因为配置了class=”org.mybatis.spring.mapper.MapperScannerConfigurer”,而这句代码会在数据源加载前就执行了,之后就把表达式${jdbc.driverClass}当成字符串执行了。

第二种:

<!-- 配制会话工厂 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    //此处省略相关代码
</bean>

将id=”sessionFactory” 改成 id=”sqlSessionFactory”
然后将方第一种方法中的 注释掉。

原因分析:当id=”sqlSessionFactory”时程序会在Ioc容器中自动装配。

猜你喜欢

转载自blog.csdn.net/zxd1435513775/article/details/79258933