我正在尝试在我的java web应用程序中使用oracle数据库,但是当我将代码作为java应用程序运行时,我一直收到错误:
线程中的异常" main" javax.persistence.PersistenceException:没有名为databaseTest
的EntityManager的持久性提供程序
这里是我的代码,只是一个创建实体管理器的简单代码:
package com.sabir.test;
import javax.persistence.Persistence;
public class DatabaseService {
public static void main(String[] args) {
System.out.println("test");
Persistence.createEntityManagerFactory("databaseTest");
}
}
这是我的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 persistence_1_0.xsd" version="1.0">
<persistence-unit name= "databaseTest" transaction-type="RESOURCE_LOCAL">
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
<exclude-unlisted-classes>false</exclude-unlisted-classes>
<properties>
<property name="javax.persistence.jdbc.driver" value="oracle.jdbc.OracleDriver"/>
<property name="javax.persistence.jdbc.url" value="jdbc:oracle:thin:@localhost:1521:orcl"/>
<property name="javax.persistence.jdbc.user" value="HR"/>
<property name="javax.persistence.jdbc.password" value="password"/>
</properties>
</persistence-unit>
</persistence>
如果需要,这是我的pom.xml文件:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.sabir.test</groupId>
<artifactId>databaseTest</artifactId>
<packaging>war</packaging>
<version>0.0.1-SNAPSHOT</version>
<name>databaseTest Maven Webapp</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.oracle</groupId>
<artifactId>ojdbc6</artifactId>
<version>11.2.0.3</version>
</dependency>
<dependency>
<groupId>org.eclipse.persistence</groupId>
<artifactId>eclipselink</artifactId>
<version>2.5.0-RC1</version>
<scope>compile</scope>
</dependency>
</dependencies>
<repositories>
<repository>
<id>codelds</id>
<url>https://code.lds.org/nexus/content/groups/main-repo</url>
</repository>
<repository>
<id>oss.sonatype.org</id>
<name>OSS Sonatype Staging</name>
<url>https://oss.sonatype.org/content/groups/staging</url>
</repository>
<repository>
<id>EclipseLink</id>
<url>http://download.eclipse.org/rt/eclipselink/maven.repo</url>
</repository>
</repositories>
<build>
<finalName>databaseTest</finalName>
</build>
</project>
我不知道为什么我会收到错误!这里也是我的文件结构:
我怀疑文件结构,但在我检查了很多网站后,我相信这是正确的。我还在maven中导入了eclipslink,所以我相信这就是我所需要的,我还添加了存储库或oracle。
我的数据库也已启动并运行,我可以从oracle开发人员工具
查询答案 0 :(得分:0)
首先检查构建路径上是否有Maven Libraries。 在Eclipse中你会去
Project Properties -> Java Build Path -> Libraries.
如果您这样做,请查看以下内容:
您在类路径上没有提供的提供商。
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
我建议将以下内容添加到您的依赖项中(并删除eclipselink依赖项):
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-api</artifactId>
<version>7.0</version>
<scope>provided</scope>
</dependency>
或将eclipselink依赖项更改为
<dependency>
<groupId>org.eclipse.persistence</groupId>
<artifactId>org.eclipse.persistence.jpa</artifactId>
<version>2.6.4</version>
</dependency>
如何以及从何处从EntityManagerFactory获取EntityManager? 我只看到您正在创建EntityManagerFactory的实例。 它应该是
EntityManagerFactory emf = Persistence.createEntityManagerFactory("databaseTest");
EntityManager em = emf.createEntityManager();
通常,只有在Java SE环境中进行引导时,此方法才有用。 相反,您可以使用依赖注入:
@PersistenceContext
EntityManager em;
或
@PersistenceUnit(unitName="myUnit")
EntityMangerFactory emf;
然后在您的方法中,您可以再次获取EntityManager,如下所示
EntityManager em = emf.createEntityManager();
或者您可以使用JNDI查找。