gpt4 book ai didi

mysql - Spring Boot MySQL REST 错误 - 需要一个名为 'entityManagerFactory'/'emf' 的 bean,但无法找到

转载 作者:行者123 更新时间:2023-11-29 11:02:56 24 4
gpt4 key购买 nike

我正在尝试使用 Spring Boot MySQL 创建一个非常简单的 REST 服务。但无法解决该错误。我做了很多搜索,大多数结果告诉我,下面的代码足以构建一个可以执行 CRUD 操作的基本 REST 服务。

我不断收到错误

***************************
APPLICATION FAILED TO START
***************************
Description:
Field repo in org.bluedolphin.spring.data.mysql.ActorController required a bean named 'entityManagerFactory' that could not be found.
Action:
Consider defining a bean named 'entityManagerFactory' in your configuration.

一旦我添加了该行

@EnableJpaRepositories(basePackages="org.bluedolphin.spring.data.mysql", entityManagerFactoryRef="emf")

在文件 SpringDataMysqlApplication 中,我开始收到以下错误

***************************
APPLICATION FAILED TO START
***************************
Description:
Field repo in org.bluedolphin.spring.data.mysql.ActorController required a bean named 'emf' that could not be found.
Action:
Consider defining a bean named 'emf' in your configuration.

完整代码如下。

应用程序属性

#Server details
server.port=8180
# Replace with your connection string
spring.datasource.url=jdbc:mysql://localhost:3307/sakila
# Replace with your credentials
spring.datasource.username=root
spring.datasource.password=password
spring.datasource.driverClassName=com.mysql.jdbc.Driver

SpringDataMysql应用程序

@SpringBootApplication
@EnableJpaRepositories(basePackages="org.bluedolphin.spring.data.mysql", entityManagerFactoryRef="emf")
public class SpringDataMysqlApplication {

private static final Logger log = LoggerFactory.getLogger(SpringDataMysqlApplication.class);

public static void main(String[] args) {
SpringApplication.run(SpringDataMysqlApplication.class, args);
}
}

Actor

@Entity
@Table(name = "actor")
public class Actor {

@Id
@GeneratedValue(strategy=GenerationType.AUTO)
private long id;
private String first_name;
private String last_name;
private Date last_update;

public Actor(int id, String first_name, String last_name, Date last_update) {
super();
this.id = id;
this.first_name = first_name;
this.last_name = last_name;
this.last_update = last_update;
}

public Actor() {
super();
}


public long getId() {
return id;
}

public void setId(long id) {
this.id = id;
}

public String getFirst_name() {
return first_name;
}

public void setFirst_name(String first_name) {
this.first_name = first_name;
}

public String getLast_name() {
return last_name;
}

public void setLast_name(String last_name) {
this.last_name = last_name;
}

public Date getLast_update() {
return last_update;
}

public void setLast_update(Date last_update) {
this.last_update = last_update;
}

@Override
public String toString() {
return "Actor [id=" + id + ", first_name=" + first_name + ", last_name=" + last_name + ", last_update="
+ last_update + "]";
}
}

Actor 存储库

public interface ActorRepository extends CrudRepository<Actor, Long> {

}

POM

<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.bluedolphin.spring.data.mysql</groupId>
<artifactId>spring-data-mysql</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>spring-data-mysql</name>
<description>spring-data-mysql</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.0.BUILD-SNAPSHOT</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>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
<repositories>
<repository>
<id>spring-snapshots</id>
<name>Spring Snapshots</name>
<url>https://repo.spring.io/snapshot</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>spring-snapshots</id>
<name>Spring Snapshots</name>
<url>https://repo.spring.io/snapshot</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
</pluginRepository>
<pluginRepository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</pluginRepository>
</pluginRepositories>
</project>

最佳答案

错误消息是不言自明的,您错过了定义实体管理器工厂 bean。你可以像下面这样在 spring config xml 文件中定义它。

<bean id="emf"
class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="persistenceUnitName" value="DataPersistencePersistenceUnit" />
<property name="dataSource" ref="yourDataSource" />
</bean>

如果在您的 Spring Boot 应用程序中没有任何 Spring 配置文件,则只需使用 EnableJpaRepositories 而无需显式提供对实体管理器的引用。

@EnableJpaRepositories(basePackages="org.bluedolphin.spring.data.mysql")

关于mysql - Spring Boot MySQL REST 错误 - 需要一个名为 'entityManagerFactory'/'emf' 的 bean,但无法找到,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41916680/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com