Ошибка создания bean-компонента с именем entityManagerFactory, определенным в ресурсе пути к классу: сбой при вызове метода инициализации

115

Когда я компилирую свой весенний проект, я получил следующую ошибку.

Ошибка при создании bean-компонента с именем entityManagerFactory, определенным в ресурсе пути к классам [org / springframework / boot / autoconfigure / orm / jpa / HibernateJpaAutoConfiguration.class]: не удалось вызвать метод инициализации

Я использую STS Eclipse и MySql Database

Моя строка соединения в Application.PropertiesIS

spring.datasource.url=jdbc:mysql://localhost:3306/stgdb
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.jpa.hibernate.ddl-auto=update

Подробная ошибка приведена ниже.

=================================================

2016-10-15 15:34:38.875[0;39m [31mERROR[0;39m [35m3700[0;39m [2m---[0;39m [2m[           main][0;39m [36mo.s.boot.SpringApplication              [0;39m [2m:[0;39m Application startup failed

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/autoconfigure/orm/jpa/HibernateJpaAutoConfiguration.class]: Invocation of init method failed; nested exception is javax.persistence.PersistenceException: [PersistenceUnit: default] Unable to build Hibernate SessionFactory
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1583) ~[spring-beans-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:545) ~[spring-beans-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:482) ~[spring-beans-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:306) ~[spring-beans-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230) ~[spring-beans-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302) ~[spring-beans-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197) ~[spring-beans-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:1076) ~[spring-context-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:851) ~[spring-context-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:541) ~[spring-context-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:122) ~[spring-boot-1.4.1.RELEASE.jar:1.4.1.RELEASE]
    at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:761) [spring-boot-1.4.1.RELEASE.jar:1.4.1.RELEASE]
    at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:371) [spring-boot-1.4.1.RELEASE.jar:1.4.1.RELEASE]
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:315) [spring-boot-1.4.1.RELEASE.jar:1.4.1.RELEASE]
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1186) [spring-boot-1.4.1.RELEASE.jar:1.4.1.RELEASE]
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1175) [spring-boot-1.4.1.RELEASE.jar:1.4.1.RELEASE]
    at com.s2g.testrestapplication.TestRestApplication.main(TestRestApplication.java:10) [classes/:na]
Caused by: javax.persistence.PersistenceException: [PersistenceUnit: default] Unable to build Hibernate SessionFactory
    at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.persistenceException(EntityManagerFactoryBuilderImpl.java:954) ~[hibernate-entitymanager-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:882) ~[hibernate-entitymanager-5.0.11.Final.jar:5.0.11.Final]
    at org.springframework.orm.jpa.vendor.SpringHibernateJpaPersistenceProvider.createContainerEntityManagerFactory(SpringHibernateJpaPersistenceProvider.java:60) ~[spring-orm-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.createNativeEntityManagerFactory(LocalContainerEntityManagerFactoryBean.java:353) ~[spring-orm-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.buildNativeEntityManagerFactory(AbstractEntityManagerFactoryBean.java:373) ~[spring-orm-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.afterPropertiesSet(AbstractEntityManagerFactoryBean.java:362) ~[spring-orm-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1642) ~[spring-beans-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1579) ~[spring-beans-4.3.3.RELEASE.jar:4.3.3.RELEASE]
    ... 16 common frames omitted
Caused by: org.hibernate.exception.GenericJDBCException: Unable to obtain JDBC Connection
    at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:47) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:109) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:95) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.tool.schema.extract.internal.ExtractionContextImpl.getJdbcConnection(ExtractionContextImpl.java:65) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.tool.schema.extract.internal.ExtractionContextImpl.getJdbcDatabaseMetaData(ExtractionContextImpl.java:75) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.tool.schema.extract.internal.InformationExtractorJdbcDatabaseMetaDataImpl.locateTableInNamespace(InformationExtractorJdbcDatabaseMetaDataImpl.java:339) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.tool.schema.extract.internal.InformationExtractorJdbcDatabaseMetaDataImpl.getTable(InformationExtractorJdbcDatabaseMetaDataImpl.java:241) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.tool.schema.extract.internal.DatabaseInformationImpl.getTableInformation(DatabaseInformationImpl.java:105) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.tool.schema.internal.SchemaMigratorImpl.doMigrationToTargets(SchemaMigratorImpl.java:162) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.tool.schema.internal.SchemaMigratorImpl.doMigration(SchemaMigratorImpl.java:60) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.tool.hbm2ddl.SchemaUpdate.execute(SchemaUpdate.java:134) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.tool.hbm2ddl.SchemaUpdate.execute(SchemaUpdate.java:101) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.internal.SessionFactoryImpl.<init>(SessionFactoryImpl.java:472) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.boot.internal.SessionFactoryBuilderImpl.build(SessionFactoryBuilderImpl.java:444) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:879) ~[hibernate-entitymanager-5.0.11.Final.jar:5.0.11.Final]
    ... 22 common frames omitted
Caused by: com.atomikos.jdbc.AtomikosSQLException: Connection pool exhausted - try increasing 'maxPoolSize' and/or 'borrowConnectionTimeout' on the DataSourceBean.
    at com.atomikos.jdbc.AtomikosSQLException.throwAtomikosSQLException(AtomikosSQLException.java:46) ~[transactions-jdbc-3.9.3.jar:na]
    at com.atomikos.jdbc.AbstractDataSourceBean.throwAtomikosSQLException(AbstractDataSourceBean.java:90) ~[transactions-jdbc-3.9.3.jar:na]
    at com.atomikos.jdbc.AbstractDataSourceBean.throwAtomikosSQLException(AbstractDataSourceBean.java:85) ~[transactions-jdbc-3.9.3.jar:na]
    at com.atomikos.jdbc.AbstractDataSourceBean.getConnection(AbstractDataSourceBean.java:347) ~[transactions-jdbc-3.9.3.jar:na]
    at com.atomikos.jdbc.AbstractDataSourceBean.getConnection(AbstractDataSourceBean.java:394) ~[transactions-jdbc-3.9.3.jar:na]
    at org.hibernate.engine.jdbc.connections.internal.DatasourceConnectionProviderImpl.getConnection(DatasourceConnectionProviderImpl.java:122) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator$ConnectionProviderJdbcConnectionAccess.obtainConnection(JdbcEnvironmentInitiator.java:180) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    at org.hibernate.tool.schema.extract.internal.ExtractionContextImpl.getJdbcConnection(ExtractionContextImpl.java:62) ~[hibernate-core-5.0.11.Final.jar:5.0.11.Final]
    ... 33 common frames omitted
==============================
Pom.xml file
<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>com.s2g.testrestapplication</groupId>
    <artifactId>testrestapplication</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>TestRestApplication</name>
    <description>Demo project for Spring Boot</description>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.4.1.RELEASE</version>
        <relativePath /> <!-- lookup parent from repository -->
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.2.2</version>
        </dependency>

        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.2.2</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.opensaml</groupId>
            <artifactId>opensaml-saml-api</artifactId>
            <version>3.1.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.0</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jersey</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jta-atomikos</artifactId>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>


</project>
thevikasdube
источник
3
Очевидно, «ошибка», которую вы получили, на самом деле была «вызвана: com.atomikos.jdbc.AtomikosSQLException: пул соединений исчерпан - попробуйте увеличить maxPoolSize и / или заимствоватьConnectionTimeout» в DataSourceBean.
Нил Стоктон

Ответы:

78

Я бы начал с добавления следующей зависимости:

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

и

<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-entitymanager</artifactId>
    <version>5.2.3.Final</version>
</dependency>

ОБНОВЛЕНИЕ : или просто добавьте следующую зависимость.

<dependency>
        <groupId>javax.xml.bind</groupId>
        <artifactId>jaxb-api</artifactId>
        <version>2.3.0</version>
</dependency>
торттестико
источник
33
@ georges-van Я столкнулся с той же ошибкой, и две упомянутые вами зависимости уже присутствуют. spring-boot-starter-data-jpaЯ получаю следующую ошибку. anotepad.com/notes/wpjr5g
@georgesvan У меня уже есть вышеуказанные банки, которые, как вы упомянули, импортированы из весенней загрузки. То, что вы думаете, может быть причиной той же ошибки. Я сталкиваюсь с той же проблемой, когда добавляю какие-либо зависимости, связанные со спящим режимом. Когда я использую java-файлы из пакета javax.persistence, все в порядке, но когда я использую любые java-файлы из пакета org.hibernate, выскакивает та же самая ошибка.
user641887
1
Просто используйте те же версии, которые указаны в сообщении.
A
4
@georges, thevikasdube уже использует зависимость spring-boot-starter-data-jpa, которая включает Hibernate. Любая причина, по которой он должен явно включать зависимости спящего режима?
Mav55
6
FYI hibernate-entitymanagerтеперь устарел. hibernate-coreВместо этого используйте (только) .
Bohemian
74

Люди, использующие java 9, включают эту зависимость: -

<dependency>
        <groupId>javax.xml.bind</groupId>
        <artifactId>jaxb-api</artifactId>
        <version>2.3.0</version>
</dependency>
Рахул Джангра
источник
4
Для тех, кто интересуется, почему версии Java 8 требуют этого явного включения, есть интересная статья здесь; baeldung.com/java-9-jaxbexception , в основном это связано с введением модульной системы в Java 9 и попыткой сократить количество
ненужных библиотек
У меня это сработало, хотя я использую Java 8, спасибо.
ahmetcetin
Что это может быть для Gradle?
FlexEast
Проблема решена, спасибо
bileleleuch
18

Добавление зависимостей не устранило проблему с моей стороны.

Проблема возникла на моем конце из-за «дополнительных» полей, которые являются частью класса «@Entity» и не существуют в базе данных.

Я удалил дополнительные поля из класса @Entity, и это сработало.

Удачи.

JAD
источник
1
Что ты подразумеваешь под дополнительными полями ?? Не могли бы вы подробнее рассказать об этом? у меня
такая
Я имел в виду дополнительные свойства, которых нет в базе данных, такие как частные / общедоступные целые числа и т.
Д.
Работал.! В моем классе Entity было два конструктора (arg, no-arg). Я удалил их, и это сработало. Спасибо @JAD. счастливого кодирования.
Bandham Manikanta
Да, эта проблема может быть связана с проблемой в любом из классов сущностей.
zee
Работал! Ошибка не связана с проблемой конфигурации или зависимостью диспетчера сущностей. Проблема была в одном из моих классов сущностей. После того, как я создал свои классы сущностей с помощью диспетчера постоянства, проблема была решена. Спасибо.
Питер
9

Я тоже столкнулся с той же проблемой. Я использовал Java9 и следующую зависимость в файле pom:

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-jdbc</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>com.h2database</groupId>
        <artifactId>h2</artifactId>
        <scope>runtime</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

Проблема была решена после добавления нижеприведенной зависимости в pom:

    <dependency>
        <groupId>javax.xml.bind</groupId>
        <artifactId>jaxb-api</artifactId>
        <version>2.3.0</version>
    </dependency>
GG
источник
8
Это дубликат ответа Рахула Джангра: stackoverflow.com/a/49707331/636009
Дэвид Конрад,
7

Я подозреваю, что jar-файлы hibernate-coreи hibernate-entitymanagerзависимости повреждены или неправильно установлены на вашем компьютере.

Я предлагаю вам просто удалить папки с именами hibernate-coreи hibernate-entitymanagerиз локального репозитория Maven, и Maven переустановит их.

Расположение по умолчанию для локального репозитория Maven - C:\Documents and Settings\[USERNAME]\.m2в Windows или ~/.m2Linux / Mac.

Хешам Усама
источник
У меня это сработало, я обновил версию весенней загрузки с 1.5 до 2.3 и получал эту ошибку.
Ali786
Я удалил свой полный репозиторий, и он работает. Он решил эту и многие другие ошибки с весенней загрузкой
Эдуардо Паскуаль Асефф 01
5

В моем случае удаление любой из приведенных ниже аннотаций вызывает, например, сообщение об ошибке entityManagerFactory.

 @Id
  @GeneratedValue(strategy=GenerationType.AUTO)

или

@ManyToMany(targetEntity=listOfObject_x.class)

Сообщение об ошибке исчезает после добавления недостающих аннотаций.

package mypackage_unameit;
import javax.persistence.PrePersist;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;

import lombok.Data;

@Data
@Entity
public class Someclasss {

  @Id
  @GeneratedValue(strategy=GenerationType.AUTO)
  private Long id;

  @NotNull
  @Size(min=5, message="Name must be at least 5 characters long")
  private String name;

  private Date createdAt;

  @ManyToMany(targetEntity=listOfObject_x.class)
  @Size(min=1, message="You must choose at least 1 ingredient")
  private List<listOfObject_x>   = new ArrayList<>();

  @PrePersist
  void createdAt() {
    this.createdAt = new Date();
  }
}
зи
источник
5

Имею jdk-12.0.2.jdk, нашел решение проблемы, добавляю зависимости в pom.xml:

<!-- https://mvnrepository.com/artifact/javax.xml.bind/jaxb-api -->
<dependency>
    <groupId>javax.xml.bind</groupId>
    <artifactId>jaxb-api</artifactId>
    <version>2.3.1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.javassist/javassist -->
<dependency>
    <groupId>org.javassist</groupId>
    <artifactId>javassist</artifactId>
    <version>3.25.0-GA</version>
</dependency>
Диего Санта-Крус Мендесу
источник
1
Спасибо, я тоже использую JDK 12, и это единственный, который мне подходит.
AnT
Может ли кто-нибудь объяснить, почему добавление этих зависимостей разрешило ошибку для некоторых из нас?
Кигс
4

Для тех, кто использует Gradle вместо Maven, добавьте это в зависимости в вашем файле сборки:

compile('javax.xml.bind:jaxb-api:2.3.0')
smo0f
источник
3

Я решил свой, обновив версии зависимостей Spring с 2.0.4 до 2.1.6

<parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.4.RELEASE</version>
        <relativePath /> <!-- lookup parent from repository -->
</parent>

к

<parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.6.RELEASE</version>
        <relativePath /> <!-- lookup parent from repository -->
</parent>
soscler
источник
Я пробовал все вышеперечисленные решения, но только это работает для меня! Спаси мой день !!!
Harriet.O
2

В моем случае это произошло из-за того, что Intellij IDEA по умолчанию установил Java 11 в качестве SDK проекта по умолчанию, но проект был реализован на Java 8. Я изменил «Project SDK» в File -> Project Structure -> Project (в настройках проекта)

Данияр
источник
Это также было моей проблемой, когда вы пытаетесь открыть старый проект, который использует Java8, с новой загруженной IntellijIDEA, это решение.
fakturk
Для установки Java8 на macOS - brew cask install accepttopenjdk / openjdk / admtopenjdk8
fakturk
2

Для тех, кто не использует JPA и вместо этого предпочитает исключить entityManagerFactory и использовать Spring Data JDBC или Spring JDBC может исключить bean-компонент, чтобы избежать исключения.

@SpringBootApplication(exclude = {HibernateJpaAutoConfiguration.class})
Мохаммад Джавед
источник
1

Мне удалось решить проблему, изменив значение максимального размера пула с одного на два.

spring.datasource.hikari.maximum-pool-size = 2

user3743729
источник
1

Попробуйте аннотировать класс с помощью @EnableTransactionManagement. Я столкнулся с той же проблемой, и она была решена путем добавления этого.

@EnableTransactionManagement
public class ConfigurationBean {
}
VaibhavD
источник
1

Я решил эту проблему, добавив в модель сериализуемые инструменты.

@Entity
@Table(name="Model_Rest")
@IdClass(Model_Rest.class)
public class Model_Rest implements Serializable {

    /**
     * 
     */
    private static final long serialVersionUID = 1L;
    /**
     * 
     */
    //@GeneratedValue(strategy = GenerationType.AUTO)
    //@Column(columnDefinition="id")

    @Id
    private String login;
    @Id
    private String password;




    @Autowired
    public String getLogin() {
        return login;
    }

    @Autowired
    public void setLogin(String login) {
        this.login = login;
    }

    @Autowired
    public String getPassword() {
        return password;
    }

    @Autowired
    public void setPassword(String password) {
        this.password = password;
    }

    public Model_Rest() {
        // TODO Auto-generated constructor stub
    }

    public Model_Rest(String login, String password) {
        this.login = login;
        this.password = password;
    }

    @Override
    public String toString() {
        return "Model_Rest [login=" + login + ", password=" + password + "]";
    }
  }
Кашьяп Нирадж
источник
1

Эта ошибка также может быть связана с тем фактом, что у вас есть ошибка в вашем "spring.datasource.url", когда вы указали неправильное имя базы данных, например

Г. Аднане
источник
0

используйте @Id. Работал для меня. В противном случае я выдаю ошибку. Это зависит от того, чего-то не хватает в вашем классе сущности или репозитории.

Радж Кумар Мишра
источник
0

Если вы используете JDK 1.8.0_201 или последнюю версию, попробуйте более старую версию JDK.

У меня такая же проблема с JDK1.8.0_201, однако он работает с JDK1.8.0_101 без изменения кода.

sin2
источник
0

Для меня это было результатом очередной ошибки

org.postgresql.util.PSQLException: FATAL: аутентификация пароля не удалась для пользователя

Это означает, что вам просто нужно проверить свои учетные данные для аутентификации.

Tanel
источник
0

Моя ошибка была решена после добавления этой зависимости.

<!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-validator -->
    <dependency>
        <groupId>org.hibernate.validator</groupId>
        <artifactId>hibernate-validator</artifactId>
        <version>6.0.16.Final</version>
    </dependency>
Лили
источник
0

Попробуйте сменить весеннюю версию. У меня была такая же проблема, и это сработало для меня

Nax
источник
0

У меня была такая же проблема с моей Eclipse Luna. Я понял, что использую JDK12 и Java 1.8. Я изменил JDK на JDK8, и проблема была решена. Если вы хотите проверить свой JDK в Eclipse, перейдите в

Window-> Preferences-> Java- >Installed JREs 

и проверьте, совместимы ли они с вашим проектом. Удачи!

Андрей
источник
0

Для меня это было название базы данных на application.properties. Когда я указал правильное имя, все заработало.

Почи
источник
0

Я решил свою проблему, определив аннотацию обратной связи для дополнительного поля

Анирудх Кханна
источник
0

У кого все еще такая же проблема. Добавьте следующую строку в application.properties

# The SQL dialect makes Hibernate generate better SQL for the chosen database
## I am using Mysql8 so I have declared MySQL8Dialect if you have other versions just add ## that version number
spring.jpa.properties.hibernate.dialect =  org.hibernate.dialect.MySQL8Dialect
Тарек Ислам
источник
-1

Я пережил аналогичную ошибку. Ошибка не появлялась раньше, но недавно я переустановил свой Oracle db и изменил имя экземпляра с xe на orcl, но забыл изменить этот фрагмент кода в файле свойств:

spring.datasource.driver-class-name=oracle.jdbc.driver.OracleDriver
spring.datasource.url=jdbc:oracle:thin:@localhost:1521:***xe***
spring.datasource.username=system
spring.datasource.password=manager

Как только я меняю его с «xe» на «orcl», все в порядке.

RBuser2769569
источник
-1

Проблема может быть в конфликте пакетов. Когда вы используете @Idаннотацию в сущности, она может использовать платформу @IdSpring; однако он должен использовать@Id аннотацию API персистентности.

Так что используйте @javax.persistence.Idаннотации в сущностях.

Орудж
источник
Если вы обращаетесь к классу, он обращается к конкретному классу со ссылкой на пакет через импорт. Если вы это сделаете, это ошибка времени компиляции, которая в первую очередь обнаруживается во время любого процесса. Так что конфликта с @Id с JPA и Spring нет.
Имам Букс
Я не уверен, на какой вопрос это пытается ответить, но это не этот вопрос. Аннотирование (или отсутствие) с помощью @Id не приведет к появлению ошибки stacktrace с сообщением «Пул соединений исчерпан - попробуйте увеличить maxPoolSize и / или заимствоватьConnectionTimeout в DataSourceBean».
Марк Роттевил
-2

Попробуйте добавить следующие зависимости.

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
   <groupId>com.h2database</groupId>
   <artifactId>h2</artifactId>
</dependency> 
Праная Викрам
источник