我有一个使用 jar 文件(lib)来访问数据库的 Web 应用程序。用作独立应用程序时的 jar 文件可以正确执行,但 webapp 收到错误:
[01-08-12 13:17:05] - 35266 WARN org.hibernate.engine.jdbc.spi.SqlExceptionHelper - SQL Error: 0, SQLState: 08001
java.sql.SQLException: No suitable driver found for jdbc:mysql://localhost:3306/myapp
我已经阅读了类似问题的答案,但没有一个能解决我的问题。
我正在使用 Maven,我在其中添加了我正在使用的 mysql 版本 5.1.21 的依赖项。事实上,我已经为 Lib 和 Webapp 添加了它。
在此之前,我尝试在 Eclipse 中定义绑定到同一文件的连接驱动程序定义,该文件已复制到我的 Webapp 的 eclipse 项目中的 WEB-INF/lib 中,并使用与下面包含的 persistence.xml 相同的参数文件
我没有使用任何java进行配置,因为我在persistence.xml文件中进行了所有配置(我已经复制到两个META-INF文件夹,一个用于app(lib),一个用于webapp。我正在使用通过 JPA 休眠(4.1.2)。
persistence.xml 文件是这样的:
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
version="2.0">
<persistence-unit name="myappPersistenceUnit"
transaction-type="RESOURCE_LOCAL">
<provider> org.hibernate.ejb.HibernatePersistence</provider>
<properties>
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect"/>
<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/myapp" />
<property name="javax.persistence.jdbc.user" value="root" />
<property name="javax.persistence.jdbc.password" value="" />
</properties>
</persistence-unit>
</persistence>
我得到的异常是在运行时,在向应用程序启动 Http 请求时,而不是在 web 应用程序的初始化时,我没有看到任何错误,但出现了这个警告:
[01-08-12 13:16:39] - 8782 WARN org.hibernate.engine.jdbc.internal.JdbcServicesImpl - HHH000342:无法获得与查询元数据的连接:找不到适合 jdbc:mysql://localhost: 的驱动程序: 3306/myapp
我猜这是因为在初始化时不需要从数据库中查找的信息,并且在这两种情况下都没有抛出异常,但根本原因相同。
编辑:我正在使用 Tomcat 6.0
任何帮助将不胜感激。