gpt4 book ai didi

java - 如何解决 org.apache.commons.dbcp.SQLNestedException

转载 作者:太空宇宙 更新时间:2023-11-04 08:42:10 25 4
gpt4 key购买 nike

我使用 hsqldb 独立版作为我的数据库。我有一个 hsqldb.jar(hsqldb-2.0.0) ,我将其添加到我的项目构建路径中,这样我的项目就会找到我的 hsqldb.jar 的位置。我正在使用 spring 来处理这些。我的 Spring Bean 是:

<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">

<bean id="sqlMapClient"
class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">

<property name="dataSource">
<ref local="adapterDataSource" />
</property>


<property name="configLocation"
value="classpath:/com/hsqldb/example/dao/ibatis/SqlMapConfig.xml" />


</bean>

<bean id="adapterDataSource"
class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<property name="driverClassName" value="org.hsqldb.jdbcDriver" />
<property name="url" value="data/db/hsqldb.jar" />
<property name="username" value="SA" />
<property name="password" value="password" />
</bean>
<bean id="testingDao" class="com.hsqldb.example.dao.TestingDao"
init-method="setTestDao" depends-on="moodleAuthenticationDetails">
<property name="sqlMapClient">
<ref local="sqlMapClient" />
</property>

</bean>
<bean id="moodleAuthenticationDetails"
class="com.hsqldb.example.HsqlDBAuthentication"></bean>
</beans>

我有一个方法会返回一个数据源,如下所示:

public static DataSource getDataSource(String filePath){
String url;
//url="jdbc:hsqldb:file:"+filePath;
url = "jdbc:hsqldb:file:D:/EclipseWorskpace/ew-pg/lmexadapter/hsqldb-example/src/main/webapp/WEB-INF/data/db/hsqldb.jar";
BasicDataSource basicDataSource = new BasicDataSource();
basicDataSource.setUsername("SA");
basicDataSource.setPassword("password");
basicDataSource.setDriverClassName("org.hsqldb.jdbc.JDBCDriver");
// basicDataSource.setUrl("jdbc:mysql://IP/moodle");
basicDataSource.setUrl(url);
System.out.println("$$$$$$$$ URL is : " + url);
return basicDataSource;
}

但是在通过 junit test 运行我的测试用例时,它给了我一个异常(exception):

org.apache.commons.dbcp.SQLNestedException: Cannot create JDBC driver of class 'org.hsqldb.jdbcDriver' for connect URL 'data/db/hsqldb.jar'
at org.apache.commons.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1273)
at org.apache.commons.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1192)
at org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDataSource.java:884)
at org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection(DataSourceUtils.java:113)
at org.springframework.jdbc.datasource.TransactionAwareDataSourceProxy$TransactionAwareInvocationHandler.invoke(TransactionAwareDataSourceProxy.java:213)
... 35 more
Caused by: java.sql.SQLException: No suitable driver
at java.sql.DriverManager.getDriver(DriverManager.java:264)
at org.apache.commons.dbcp.BasicDataSource.createConnectionFactory(BasicDataSource.java:1266)
... 39 more

请帮忙解决这个问题。

谢谢

最佳答案

Spring 配置中的 BasicDataSource url 属性不应该是 jar 的路径。查看 Spring 配置的一些示例 here .

(除非您让 Spring 意识到,否则您编写的 DataSource 类不会执行任何操作。但您不必编写这样的类 - 只需修复配置中的 url 属性即可。)

关于java - 如何解决 org.apache.commons.dbcp.SQLNestedException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5073955/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com