org.springframework.beans.factory.BeanCreationException: Ошибка Как мне решить эту проблему? - PullRequest
0 голосов
/ 17 марта 2020

Мне нужна помощь. Я использую Java со Springboot и работаю над проектом, который по существу отображает информацию из базы данных (названия книг, авторов, язык и т. Д.) На веб-странице, а навигация по сайту позволяет мне вносить изменения в база данных, такая как редактирование записи, создание новой записи, показ записи или удаление записи.

Это работало очень хорошо, пока мне не пришлось выключить компьютер, а затем, когда я вернулся и попытался запустить это Проект снова, это дает мне ошибку ниже вместе с большим количеством другого текста. Я перезапустил сервер, запустил его в режиме отладки, ничего не получалось. Это почти как если бы я разорвал какую-то связь, которая была там раньше, или я удалил что-то, что я не должен был удалить. Я просто не могу понять, что это может быть. Я надеялся, что кто-нибудь скажет мне, что я мог сделать не так, чтобы я мог повернуть его вспять и снова запустить и запустить.

Error starting ApplicationContext. To display the conditions report re-run your application with 'debug' enabled.
[2m2020-03-16 23:06:05.766[0;39m [31mERROR[0;39m [35m49106[0;39m [2m---[0;39m [2m[  restartedMain][0;39m [36mo.s.boot.SpringApplication              [0;39m [2m:[0;39m Application run failed

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/autoconfigure/orm/jpa/HibernateJpaConfiguration.class]: Invocation of init method failed; nested exception is org.hibernate.service.spi.ServiceException: Unable to create requested service [org.hibernate.engine.jdbc.env.spi.JdbcEnvironment]

Обратите внимание, что я не узнал о "спящем режиме" напрямую, а только слышал об этом термине, когда увидел эту ошибку и попытался найти ее в поиске. Я попробовал некоторые другие решения, упомянутые в stackoverflow, для людей с очень похожей проблемой, но у меня это не работает (а именно, добавление специфической c зависимости в отношении спящего режима, но я не помню подробности этого сейчас ))

Ниже приведен код, который я использовал для различных пакетов:

Свойство

spring.datasource.url=jdbc:mysql://localhost:3306/book-schema2 
spring.datasource.username=root 
spring.datasource.password=root 
spring.datasource.driver-class-name=com.mysql.jdbc.Driver 
spring.jpa.hibernate.ddl-auto=update 
spring.mvc.view.prefix=/WEB-INF/

В файл pom. xml:

<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.5.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.blank.mvc2</groupId>
    <artifactId>mvc2</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>mvc2</name>
    <description>mvc2</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <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-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </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>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.apache.tomcat.embed</groupId>
            <artifactId>tomcat-embed-jasper</artifactId>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jstl</artifactId>
        </dependency>
    </dependencies>

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

</project>

В пакете моделей: import java .util.Date;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.PrePersist;
import javax.persistence.PreUpdate;
import javax.persistence.Table;
import javax.validation.constraints.Min;
import javax.validation.constraints.Size;

import org.springframework.format.annotation.DateTimeFormat;

@Entity
@Table(name="books2")
public class Book {

В пакете репозиториев:

import java.util.List;
import java.util.Optional;

import org.springframework.data.repository.CrudRepository;
import org.springframework.stereotype.Repository;

@Repository
public interface BookRepository extends CrudRepository<Book, Long> {

В пакете услуг:

import java.util.List;
import java.util.Optional;

import org.springframework.stereotype.Service;

@Service
public class BookService {

В пакете контроллеров:

import java.util.List;

import javax.validation.Valid;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;

@Controller
public class BooksController {

Имейте в виду, я уже делал этот проект, и снова делал его для практики, и оба проекта работали раньше, но сейчас ни один проект не работает. Он работал нормально, пока я не перезагрузил свой компьютер (никаких обновлений на самом компьютере за это время не было). Если вы хотите больше информации, дайте мне знать. Мне просто нужна помощь в выяснении этого прямо сейчас, поскольку для меня нет никакого смысла, почему он будет работать одну минуту, а затем, просто включив / выключив компьютер, он не будет работать в следующую минуту.

Ответы [ 2 ]

0 голосов
/ 19 марта 2020

Хорошо, так что ничего не работало, и после того, как я стал больше копаться в Интернете, я нашел решение, но не понял, как его реализовать, и будет ли оно вообще работать. Конечно же, я нашел видео на Youtube (https://www.youtube.com/watch?v=nO0IaGrlGPc), в котором он объясняет его шаг за шагом и как его решить.

TLDR: у меня изначально было spring.datasource.url=jdbc:mysql://localhost:3306/book-schema в моих свойствах , но получал несколько ошибок, одной из которых было EDT, не распознанный часовой пояс. Похоже, именно это и послужило причиной других ошибок.

Итак, что у меня сейчас в свойствах:

spring.datasource.url=jdbc:mysql://localhost:3306/book-schema?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC

Программа теперь работает так же, как и раньше. (Я думаю, что, возможно, летнее время 8 марта сыграло свою роль? Я не знаю, но оно работало нормально, а потом вдруг говорит, что не распознает EDT.)

Спасибо все, кто пытался помочь мне решить эту проблему.

0 голосов
/ 17 марта 2020

Это явно проблема с подключением к БД. Hibernate не может подключиться к вашей БД. Попробуйте перезапустить БД и приложение после перезапуска БД, он должен работать нормально.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...