我是Spring环境的新手。我正在尝试使用SpringBoot和Hibernate作为ORM和MYSQL作为数据库来开发基本的MVC应用程序。我遇到了许多麻烦来设置依赖项和配置。目前,我对以下错误感到震惊,我无法弄清楚如何克服它。
org.springframework.beans.factory.BeanCreationException: Cannot determine embedded database driver class for database type NONE. If you want an embedded database please put a supported one on the classpath.
这是我在我的应用程序中的设置。它没有服务层和jsp页面以避免混乱
数据库:
MySql - 名为Users的数据库已存在,它有一个名为Users的表,其中包含一个用户样本列表
User.java(型号)
@Entity
@Table(name = "Users")
public class User {
@Id
@GeneratedValue
public String id;
public String username;
public String firstname;
public String lastname;
public String password;
}
UserRepository:
@Repository
@Table(name = "Users")
public interface UserRepository extends JpaRepository<User, String> {
}
UserController中:
@RestController
public class UserController {
private UserRepository userRepository;
@Autowired
public UserController(UserRepository userRepository)
{
this.userRepository = userRepository;
}
@RequestMapping("user")
public void getUser(@RequestParam("id") String id) {
User user = userRepository.findOne(id);
}
}
Application.properties:
server.port:9000
spring.datasource.url:jdbc:mysql:// localhost / Users
spring.datasource.driverClassName:com.mysql.jdbc.Driver
spring.datasource.username:root
spring.datasource.password:
的pom.xml
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.1.3.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
<exclusions>
<exclusion>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-entitymanager</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- HIBERNATE -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>4.3.0.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-entitymanager</artifactId>
<version>4.3.0.Final</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.hibernate.javax.persistence</groupId>
<artifactId>hibernate-jpa-2.0-api</artifactId>
<optional>true</optional>
</dependency>
<!-- Spring ORM, works with Hibernate -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-orm</artifactId>
</dependency>
<!-- MYSQL -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
</dependencies>
编辑:添加主要课程
MAIN CLASS
@ComponentScan
@Configuration
@EnableAutoConfiguration
public class ApplicationStart {
public static void main(String[] args)
{
SpringApplication.run(ApplicationStart.class, args);
}
}
这是我的应用程序的当前设置。我似乎甚至不知道在哪里寻找错误,互联网上的教程对我的事业没有帮助。因此,非常感谢任何有关如何解决异常的帮助。
如果需要更多信息,请发表评论。
谢谢 -
答案 0 :(得分:14)
确保application.properties
位于supported locations之一。
- 当前目录的A / config子目录。
- 当前目录
- classpath / config包
- 类路径根
醇>列表按优先顺序排列(列表中较高的位置覆盖较低的项目)。
虽然使用:
分隔属性文件中的键/值对应该可行,但我建议坚持使用更常用的=
分隔符。
你的pom包含一些不必要的混乱,我建议你移动。您应该只需要依赖mysql-connector-java
其他所有内容都是混乱的(其他依赖项是通过您依赖的入门项目提供的。)
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<!-- MYSQL -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
</dependencies>
这些应该是您需要的一切,版本和传递依赖关系由spring-boot-dependency pom.xml处理。 (初级父母的祖父母)。
使用@EnableAutoConfiguration
注释时,带注释的类也将用于确定from which package开始扫描。通常,您会将此注释放在入门类中。建议将此应用程序类放在顶级包中(即your.package.application.StarterClass
)所有其他包应该是该包的子包。这样,将自动检测所有类。
如果无法做到这一点,您可能需要添加额外的@ComponentScan
来指定开始扫描的基础包,并@EntityScan
指定包含您的实体的包。< / p>
答案 1 :(得分:0)
我也面临同样的问题,但原因却大不相同,我尝试了上面提到的所有事情,所有答案都用了2个小时。但最后才知道我的文件属性名称'Application.properties'是以大写'A'开头的。它应该是小'A'。所以请同时考虑这一点。