java.lang.ClassNotFoundException:无法加载请求的类:org.postgresql.Driver

问题描述 投票:0回答:2

我的问题是当我在 Bean 中创建 DAO 实例时

public class ClientDAO {
        EntityManager entity=JPAutil.getEntityManegerFactory().createEntityManager();

    public void create(Client client){
        entity.getTransaction().begin();
        entity.persist(client);
        entity.getTransaction().commit();
        JPAutil.shotDown();
    }
    public void update(Client client){
        entity.getTransaction().begin();
        entity.merge(client);
        entity.getTransaction().commit();
        JPAutil.shotDown();
    }
    public void find(int id){
        entity.getTransaction().begin();
        entity.find(Client.class,id);
    }
    public List<Client> findall(){
            List<Client> listaC= new ArrayList<Client>();
            Query q=entity.createQuery("SELECT c FROM Client c");
            listaC = q.getResultList();
            return listaC;
    }
    public Client findbyId(int idc){
        Client C= new Client();
        Query q=entity.createQuery("SELECT c FROM Client c WHERE id="+idc);
        C = (Client) q.getSingleResult();
        return C;
    }
}

我尝试运行应用程序,但服务器崩溃了

Caused by: org.hibernate.boot.registry.classloading.spi.ClassLoadingException: Unable to load class [org.postgresql.Driver]
    at [email protected]//org.hibernate.boot.registry.classloading.internal.ClassLoaderServiceImpl.classForName(ClassLoaderServiceImpl.java:134)
    at [email protected]//org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl.loadDriverIfPossible(DriverManagerConnectionProviderImpl.java:163)
    at [email protected]//org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl.buildCreator(DriverManagerConnectionProviderImpl.java:119)
    at [email protected]//org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl.buildPool(DriverManagerConnectionProviderImpl.java:103)
    at [email protected]//org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl.configure(DriverManagerConnectionProviderImpl.java:75)
    at [email protected]//org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java:100)
    at [email protected]//org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:246)
    at [email protected]//org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:214)
    at [email protected]//org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.buildJdbcConnectionAccess(JdbcEnvironmentInitiator.java:145)
    at [email protected]//org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.initiateService(JdbcEnvironmentInitiator.java:66)
    at [email protected]//org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.initiateService(JdbcEnvironmentInitiator.java:35)
    at [email protected]//org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.initiateService(StandardServiceRegistryImpl.java:94)
    at [email protected]//org.hibernate.service.internal.AbstractServiceRegistryImpl.createService(AbstractServiceRegistryImpl.java:263)
    ... 98 more
Caused by: java.lang.ClassNotFoundException: Could not load requested class : org.postgresql.Driver
    at [email protected]//org.hibernate.boot.registry.classloading.internal.AggregatedClassLoader.findClass(AggregatedClassLoader.java:210)
    at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:588)
    at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:521)
    at java.base/java.lang.Class.forName0(Native Method)
    at java.base/java.lang.Class.forName(Class.java:398)
    at [email protected]//org.hibernate.boot.registry.classloading.internal.ClassLoaderServiceImpl.classForName(ClassLoaderServiceImpl.java:131)
    ... 110 more

感谢您的宝贵时间。

Pom.xml 我已经使测试和本地 JPA 工作没有问题,问题是当我尝试在服务器中使用它时。在此 Pom 中有一个驱动程序 von Postgres 和连接器 Hibernate。

<?xml version="1.0" encoding="UTF-8"?>
<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/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>groupId</groupId>
    <artifactId>pruebe</artifactId>
    <version>1.0-SNAPSHOT</version>

    <!---Servlet-->
    <dependencies>
        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-api</artifactId>
            <version>8.0</version>
            <scope>provided</scope>
        </dependency>

        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-entitymanager</artifactId>
            <version>5.4.10.Final</version>
        </dependency>
        <dependency>
            <groupId>postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <version>9.1-901.jdbc4</version>
            <scope>compile</scope>
        </dependency>

    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.5.1</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>  
</project>```


jpa driver classnotfoundexception
2个回答
0
投票

您需要将 JDBC 驱动程序连接到您的项目中的数据库,您可以从这里下载它 https://jdbc.postgresql.org/


0
投票

出现同样的错误,你是如何解决的

© www.soinside.com 2019 - 2024. All rights reserved.