java.sql.SQLException: нет подходящего драйвера при чтении данных из базы данных

#java #hibernate #postgresql #jdbc #web.xml

#java #гибернация #postgresql #jdbc #web.xml

Вопрос:

Я пытаюсь создать веб-приложение, которое извлекает данные из базы данных postgresql, и это файлы конфигурации :

web.xml

   <?xml version="1.0" encoding="ASCII"?>
    <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0">
      <display-name></display-name>
      <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>/WEB-INF/classes/application-context.xml</param-value>
      </context-param>
      <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
      </listener>
      <listener>
        <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class>
      </listener>
      <servlet>
        <servlet-name>Faces Servlet</servlet-name>
        <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
        <load-on-startup>1</load-on-startup>
      </servlet>
      <servlet-mapping>
        <servlet-name>Faces Servlet</servlet-name>
        <url-pattern>*.jsf</url-pattern>
      </servlet-mapping>
      <welcome-file-list>
        <welcome-file>index.jsf</welcome-file>
      </welcome-file-list>
    </web-app>
  

приложение-контекст

 <?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:security="http://www.springframework.org/schema/security"
    xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd
        http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-4.0.xsd
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
        http://www.springframework.org/ schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd">

    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value ="org.postgresql.Driver" />
        <property name="user" value="postgres" />
        <property name="password" value="toor"/>
        <property name="jdbcUrl" value="jdbc:postgresql://172.16.83.128:5432/emaeval" />
    </bean>
    <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="packagesToScan" value="com.models" />
        <property name="hibernateProperties">
            <props>
                <prop key="hiberante.dialect">org.hibernate.dialect.PostgreSQLDialect</prop>
                <prop key="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</prop>
            </props>
        </property>

    </bean>
    <bean id="tansactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory"></property>
    </bean>
    <tx:annotation-driven transaction-manager="transactionManager"/>
    <context:annotation-config/>
    <context:component-scan base-package="com"></context:component-scan>
</beans>
  

но когда я запускаю свое приложение, я получаю эти ошибки :

 AVERTISSEMENT: com.mchange.v2.resourcepool.BasicResourcePool$ScatteredAcquireTask@3f7cb1d0 -- Acquisition Attempt Failed!!! Clearing pending acquires. While trying to acquire a needed new resource, we failed to succeed more than the maximum number of allowed acquisition attempts (30). Last acquisition attempt exception: 
java.sql.SQLException: No suitable driver
  

И :

 GRAVE: Context initialization failed
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in ServletContext resource [/WEB-INF/classes/application-context.xml]: Invocation of init method failed; nested exception is org.hibernate.HibernateException: Access to DialectResolutionInfo cannot be null when 'hibernate.dialect' not set
  

Как я могу решить эту проблему??

Комментарии:

1. Похоже org.postgresql.Driver , что в вашем пути к классу отсутствует jar, содержащий.

2. Я откатил последнее редактирование. Если у вас (совершенно) другая проблема: отправьте новый вопрос. Не изменяйте и не редактируйте свой вопрос, чтобы задать дополнительный, но не связанный с ним вопрос.

Ответ №1:

Вы неправильно написали свойство hibernate.dialect в вашем xml, поэтому ваша вторая ошибка заключается в том, что вы не установили его.

            <prop key="hiberante.dialect">org.hibernate.dialect.PostgreSQLDialect</prop>
  

должно быть

            <prop key="hibernate.dialect">org.hibernate.dialect.PostgreSQLDialect</prop>
  

Комментарии:

1. Спасибо, это была проблема, но после ее устранения у меня возникла другая проблема, пожалуйста, проверьте изменения, которые я внес в свой пост

2. ваша новая ошибка, похоже, не связана с исходным вопросом, который касался драйверов sql и т. Д. Возможно, сейчас следует опубликовать новый вопрос, поскольку он выглядит как проблема с веб-фреймворком и т. Д.