ยังไม่ได้ใช้วิธี org.postgresql.jdbc.PgConnection.createClob ()


99

ฉันจะแก้ไขข้อผิดพลาดนี้ได้อย่างไร:

java.lang.reflect.InvocationTargetException: null
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_161]
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_161]
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_161]
    at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_161]
    at org.hibernate.engine.jdbc.env.internal.LobCreatorBuilderImpl.useContextualLobCreation(LobCreatorBuilderImpl.java:113) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.engine.jdbc.env.internal.LobCreatorBuilderImpl.makeLobCreatorBuilder(LobCreatorBuilderImpl.java:54) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentImpl.<init>(JdbcEnvironmentImpl.java:271) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.initiateService(JdbcEnvironmentInitiator.java:114) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.initiateService(JdbcEnvironmentInitiator.java:35) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.initiateService(StandardServiceRegistryImpl.java:88) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.service.internal.AbstractServiceRegistryImpl.createService(AbstractServiceRegistryImpl.java:259) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:233) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:210) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure(JdbcServicesImpl.java:51) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java:94) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:242) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:210) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.boot.model.process.spi.MetadataBuildingProcess.handleTypes(MetadataBuildingProcess.java:352) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.boot.model.process.spi.MetadataBuildingProcess.complete(MetadataBuildingProcess.java:111) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.metadata(EntityManagerFactoryBuilderImpl.java:861) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:888) [hibernate-core-5.2.14.Final.jar:5.2.14.Final]
    at org.springframework.orm.jpa.vendor.SpringHibernateJpaPersistenceProvider.createContainerEntityManagerFactory(SpringHibernateJpaPersistenceProvider.java:57) [spring-orm-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.createNativeEntityManagerFactory(LocalContainerEntityManagerFactoryBean.java:365) [spring-orm-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.buildNativeEntityManagerFactory(AbstractEntityManagerFactoryBean.java:388) [spring-orm-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.afterPropertiesSet(AbstractEntityManagerFactoryBean.java:377) [spring-orm-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.afterPropertiesSet(LocalContainerEntityManagerFactoryBean.java:341) [spring-orm-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1769) [spring-beans-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1706) [spring-beans-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:583) [spring-beans-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:502) [spring-beans-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:312) [spring-beans-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:228) ~[spring-beans-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:310) [spring-beans-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:200) [spring-beans-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:1085) ~[spring-context-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:858) ~[spring-context-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:549) ~[spring-context-5.0.4.RELEASE.jar:5.0.4.RELEASE]
    at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:140) ~[spring-boot-2.0.0.RELEASE.jar:2.0.0.RELEASE]
    at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:752) ~[spring-boot-2.0.0.RELEASE.jar:2.0.0.RELEASE]
    at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:388) ~[spring-boot-2.0.0.RELEASE.jar:2.0.0.RELEASE]
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:327) ~[spring-boot-2.0.0.RELEASE.jar:2.0.0.RELEASE]
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1246) ~[spring-boot-2.0.0.RELEASE.jar:2.0.0.RELEASE]
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1234) ~[spring-boot-2.0.0.RELEASE.jar:2.0.0.RELEASE]
    at com.divergent.demo.DemoApplication.main(DemoApplication.java:12) ~[classes/:na]



Caused by: java.sql.SQLFeatureNotSupportedException: Method org.postgresql.jdbc.PgConnection.createClob() is not yet implemented.
    at org.postgresql.Driver.notImplemented(Driver.java:683) ~[postgresql-42.2.1.jar:42.2.1]
    at org.postgresql.jdbc.PgConnection.createClob(PgConnection.java:1252) ~[postgresql-42.2.1.jar:42.2.1]
    ... 44 common frames omitted

อาจมีการจำศีล
davidxxx

1
"hibernate with c32p0 ... " ไม่ได้พูดถึง Spring Boot แม้ว่าจะมีคำตอบ
ก็ตาม

คำตอบ:


200

เพิ่มคุณสมบัตินี้ใน application.properties ของคุณ:

spring.jpa.properties.hibernate.jdbc.lob.non_contextual_creation=true

อ้างอิง:


ไม่ทำงานกับ Spring Boot 2.1.6 มันเป็นไปได้ที่มีการถดถอย
cstroe

ทำงานสำหรับ 2.1.9 RELEASE
Utkarsh Gupta

30

นี่เป็นปัญหาHibernateในการแก้ปัญหาชั่วคราวคุณสามารถใช้แฟล็กต่อไปนี้ ตั้งค่าการกำหนดค่าต่อไปนี้ในคุณสมบัติของคุณ:

spring.jpa.properties.hibernate.jdbc.lob.non_contextual_creation=true

สำหรับฤดูใบไม้ผลิบูต 2.xxธงนี้เพียงแค่ปิดการใช้งานการสร้างลอบบริบท แต่ถ้าคุณต้องการที่จะรู้ว่าจริงๆต้องตอบเช็คUPDATE V1

ปรับปรุง V1.0

นี่คือ Hibernate ปัญหา หากคุณใช้ Spring Boot เวอร์ชันล่าสุดตั้งแต่2.0.xจนถึงวันที่2.1.x รวมHibernate 5.3.10.finalคุณสามารถดูได้ที่นี่แต่ปัญหานี้ได้รับการแก้ไขเมื่อHibernate version 5.4.0 CR1คุณต้องเพิ่มการอ้างอิงนั้นหรือหากเป็นไปได้เวอร์ชันล่าสุด:

สำหรับ Gradle:

compile('org.hibernate:hibernate-core:5.4.2.Final')

สำหรับ Maven:

<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-core</artifactId>
    <version>5.4.2.Final</version>
</dependency>

อัปเดต V2 "SPRING BOOT 2.2.0.M (1-4)"

นอกจากนี้ยังSpring boot v2.2.0.MxรวมถึงตอนHibernate v5.4.xนี้ปัญหานี้ได้รับการแก้ไขแล้วสำหรับเวอร์ชันเหล่านี้


1
เจ๋งฉันได้เพิ่มข้อมูลเพิ่มเติมเกี่ยวกับเรื่องนี้และอัปเดตการรองรับเวอร์ชันสำหรับสปริงบูต @ShekhFirozAlam
Jonathan JOhx

ใน Spring Boot 2.2.1.RELEASE ยังคงพบปัญหา คำตอบของโมฮัมหมัดเฮจาซีได้ผล stackoverflow.com/a/54288767/4766882
Dennis Kim

29

ฉันมีปัญหาที่คล้ายกัน ฉันทำตามวิธีแก้ปัญหานี้และได้ผลสำหรับฉัน

http://vkuzel.blogspot.com/2016/03/spring-boot-jpa-hibernate-atomikos.html

# Disable feature detection by this undocumented parameter. Check the org.hibernate.engine.jdbc.internal.JdbcServiceImpl.configure method for more details.
spring.jpa.properties.hibernate.temp.use_jdbc_metadata_defaults = false

# Because detection is disabled you have to set correct dialect by hand.
spring.jpa.database-platform=org.hibernate.dialect.PostgreSQL9Dialect

สิ่งนี้ได้ผลสำหรับฉัน อย่างไรก็ตามฉันใช้spring.jpa.database=POSTGRESQLแทนภาษาถิ่น
cbmeeks

13

แก้ไขได้โดยเพิ่มhibernate.propertiesด้วย

hibernate.jdbc.lob.non_contextual_creation=true

วิธีแก้ปัญหาอื่น ๆapplication.propertiesไม่ได้ผล ซึ่งสามารถทำได้ผ่าน XML hibernate.cfg.xml

เวอร์ชัน Spring Boot: 2.0.2 รีลีส


1
แน่ใจหรือว่าเริ่มต้นด้วย spring.jpa มันใช้งานได้ดีใน 2.0.3 สำหรับฉัน
Kalpesh Soni

@KalpeshSoni ขออภัยไม่สามารถตอบได้ เป็นโครงการฤดูใบไม้ผลิที่มีการพึ่งพาทางธุรกิจของโครงการอื่นซึ่งมีการกำหนดสิ่งที่คงอยู่ ยากที่จะทำซ้ำการตั้งค่านี้เพื่อค้นหา
Pafnucy




0

ฉันดิ้นรนกับสิ่งนี้เป็นเวลาหนึ่งวัน

  • รุ่น Spring boot 2.2.5

  • Postgres: 42.2.10

  • เวอร์ชันของ Postgres บนเซิร์ฟเวอร์: PostgreSQL 11.6 on x86_64-pc-linux-gnu, compiled by gcc (GCC) 4.9.3, 64-bit

ฉันใช้ข้อมูล Spring JPA กับการกำหนดค่าไฮเบอร์เนต ใช้ sessionFactory

การกำหนดค่าไฮเบอร์เนต:

@Bean(name = "sessionFactory")
@Primary
public LocalSessionFactoryBean sessionFactory(){
    LocalSessionFactoryBean sessionFactoryBean = new LocalSessionFactoryBean();
    sessionFactoryBean.setDataSource(assetHealthDataSource);
    sessionFactoryBean.setMappingDirectoryLocations(new Resource[]{new ClassPathResource("mappings")});
    sessionFactoryBean.setHibernateProperties(hibernateProperties());

    return sessionFactoryBean;
}

คุณสมบัติไฮเบอร์เนต:

private final Properties hibernateProperties() {
    Properties hibernateProperties = new Properties();
    hibernateProperties.setProperty(
            "hibernate.dialect", "org.hibernate.dialect.PostgreSQL9Dialect");
    hibernateProperties.setProperty(
            "hibernate.jdbc.lob.non_contextual_creation", "true");
    hibernateProperties.setProperty(
            "hibernate.temp.use_jdbc_metadata_defaults", "false");
    hibernateProperties.setProperty(
            "hibernate.show_sql", environment.getProperty("assetHealthDataSource.hibernate.showSQL"));
    hibernateProperties.setProperty(
            "hibernate.format_sql", environment.getProperty("assetHealthDataSource.hibernate.formatSQL"));
    hibernateProperties.setProperty(
            "hibernate.transaction.auto_close_session", "false");
    hibernateProperties.setProperty(
            "hibernate.hibernate.connection.release_mode", "auto");
    hibernateProperties.setProperty(
            "hibernate.hikari.maximumPoolSize", "3");
    hibernateProperties.setProperty(
            "hibernate.default_schema", "MY_SCHEMA");

    return hibernateProperties;
}

แต่ทุกอย่างทำงานไม่ถูกต้อง ยินดีที่จะเห็นข้อเสนอแนะใด ๆ ที่สามารถช่วยแก้ปัญหานี้ได้ ขอบคุณมาก.


ak มันได้รับการแก้ไขแล้ว ฉันต้องการยืนยันว่าปัญหานี้จะไม่เกิดขึ้นใน Springboot 2.2.5 และ Hibernate 4.2.14 Final ฉันได้รับข้อผิดพลาดเนื่องจากมีไดรเวอร์ Oracle อยู่ในแอปพลิเคชันอาจทำให้เกิดความขัดแย้ง ขอบคุณ.
Hung Bang Quan
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.