web-dev-qa-db-ja.com

メソッドorg.postgresql.jdbc4.Jdbc4Connection.isValid(int)はまだ実装されていません

Postgres 9.1でdbcp2を設定しようとしています

アプリを実行すると、例外がスローされます。

Exception in thread "main" org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is Java.sql.SQLException: Cannot create PoolableConnectionFactory (Method org.postgresql.jdbc4.Jdbc4Connection.isValid(int) is not yet implemented.)
    at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.Java:80)
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.Java:575)
    at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.Java:639)
    at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.Java:664)
    at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.Java:704)
    at org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate.queryForObject(NamedParameterJdbcTemplate.Java:195)
    at com.springinpractice.ch02.service.impl.ContactServiceImpl.getContact(ContactServiceImpl.Java:64)
    at com.springinpractice.ch02.ConsoleApp.main(ConsoleApp.Java:16)
Caused by: Java.sql.SQLException: Cannot create PoolableConnectionFactory (Method org.postgresql.jdbc4.Jdbc4Connection.isValid(int) is not yet implemented.)
    at org.Apache.commons.dbcp2.BasicDataSource.createPoolableConnectionFactory(BasicDataSource.Java:2152)
    at org.Apache.commons.dbcp2.BasicDataSource.createDataSource(BasicDataSource.Java:1903)
    at org.Apache.commons.dbcp2.BasicDataSource.getConnection(BasicDataSource.Java:1413)
    at org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection(DataSourceUtils.Java:111)
    at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.Java:77)
    ... 7 more
Caused by: org.postgresql.util.PSQLException: Method org.postgresql.jdbc4.Jdbc4Connection.isValid(int) is not yet implemented.
    at org.postgresql.Driver.notImplemented(Driver.Java:753)
    at org.postgresql.jdbc4.AbstractJdbc4Connection.isValid(AbstractJdbc4Connection.Java:109)
    at org.postgresql.jdbc4.Jdbc4Connection.isValid(Jdbc4Connection.Java:21)
    at org.Apache.commons.dbcp2.DelegatingConnection.isValid(DelegatingConnection.Java:914)
    at org.Apache.commons.dbcp2.PoolableConnection.validate(PoolableConnection.Java:227)
    at org.Apache.commons.dbcp2.PoolableConnectionFactory.validateConnection(PoolableConnectionFactory.Java:303)
    at org.Apache.commons.dbcp2.BasicDataSource.validateConnectionFactory(BasicDataSource.Java:2165)
    at org.Apache.commons.dbcp2.BasicDataSource.createPoolableConnectionFactory(BasicDataSource.Java:2148)
    ... 11 more

これが私のMaven POMです。

<dependencies>
    <!-- Spring and Transactions -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>${spring-framework.version}</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-tx</artifactId>
        <version>${spring-framework.version}</version>
    </dependency>

    <!-- Logging with SLF4J & LogBack -->
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>${slf4j.version}</version>
        <scope>compile</scope>
    </dependency>
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <version>${logback.version}</version>
        <scope>runtime</scope>
    </dependency>

    <!-- Hibernate -->
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-entitymanager</artifactId>
        <version>${hibernate.version}</version>
    </dependency>


    <!-- Test Artifacts -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>${spring-framework.version}</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>${junit.version}</version>
        <scope>test</scope>
    </dependency>

    <!-- For JDBC -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>${spring-framework.version}</version>
    </dependency>

    <dependency>
        <groupId>postgresql</groupId>
        <artifactId>postgresql</artifactId>
        <version>9.1-901.jdbc4</version>

    </dependency>

    <dependency>
        <groupId>org.Apache.commons</groupId>
        <artifactId>commons-dbcp2</artifactId>
        <version>2.0.1</version>
    </dependency>
    <dependency>
        <groupId>javax.inject</groupId>
        <artifactId>javax.inject</artifactId>
        <version>1</version>
    </dependency>

</dependencies>
27
janetsmith

このメソッドは、現在のドライバーバージョンに実装されています。古いPgJDBCを使用している必要があります。アップグレード。完全に下位互換性があります。 (質問でPgJDBCバージョンを指定する必要があります)。

ただし、それとは別に、通常、接続の「検証」に依存することは悪い考えです。これは、競合状態を不完全に隠そうとするだけの方法です。接続を取得して使用するだけです。問題がある場合、アプリケーションは結果の例外をトラップし、SQLSTATEをチェックして接続関連エラーかどうかを確認し、新しい接続で再試行します。

20
Craig Ringer

Postgresqlをpom.xmlの以下のエントリに置き換えます。私のPostgresバージョンはaws postgresql-9.3.10-3です。

<dependency>
  <groupId>org.postgresql</groupId>
  <artifactId>postgresql</artifactId>
  <version>9.3-1100-jdbc41</version>
</dependency>
17

クレイグは正しい。根本原因は、org.postgresqlに変更されたpostgresqlグループIDであり、古いグループは更新を取得しません。ディペンデンシーノードを更新する必要があります。つまり:

<dependency>
    <groupId>org.postgresql</groupId>
    <artifactId>postgresql</artifactId>
    <version>42.2.5</version>
</dependency>

現在の最新バージョンによる https://mvnrepository.com/artifact/org.postgresql/postgresql/

8
perimeno

解決策:パラメーター「validationQuery」の検証クエリを設定します。

例:Bean:property name = "validationQuery" value = "SELECT 1"

この検証クエリは、接続を返す前に接続に対して実行されます。したがって、有効なクエリがあります。上記はダミーのクエリです。

https://commons.Apache.org/proper/commons-dbcp/configuration.html

1
ninjakoder
    <dependency>
        <groupId>org.postgresql</groupId>
        <artifactId>postgresql</artifactId>
        <version>9.3-1100-jdbc41</version>
    </dependency>

ドライバーを変更し、動作します!

1
zhiping shu

intelliJの安全な定義(9.4.1208-jdbc42-atlassian-hostedに解決されます)

<dependency>
        <groupId>postgresql</groupId>
        <artifactId>postgresql</artifactId>
        <version>RELEASE</version>
</dependency>

または:

<dependency>
            <groupId>org.postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <version>42.2.5.jre7</version>
        </dependency>
0
dobrivoje

Maven Centralには、postgresqlの下に古いバージョンのドライバーがあります。 org.postgresql

0
Alex R

このチケットは問題の解決に役立ちました: 原因:Java.lang.NoSuchMethodError:org.postgresql.core.BaseConnection.getEncoding()Lorg/postgresql/core/Encoding;

基本的に、PostGISスタブを除外する必要があります。

 <dependency>
   <groupId>org.postgis</groupId>
   <artifactId>postgis-jdbc</artifactId>
   <version>1.3.3</version>
   <scope>compile</scope>
   <exclusions>
      <exclusion>
         <groupId>org.postgis</groupId>
         <artifactId>postgis-stubs</artifactId>
      </exclusion>
   </exclusions>
</dependency>
0
sergpank