为什么在将Spring Data JPA与Spring Boot一起使用时不会应用我的数据库自定义?

时间:2015-03-08 18:53:15

标签: spring hibernate jpa spring-boot spring-data

我试图在tutorial的Spring Boot项目中使用Spring Data JPA。这些是我的pom.xml依赖项:

<dependencies>
    <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-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <scope>runtime</scope>
    </dependency>
</dependencies>

application.properties

# DataSource settings: set here configurations for the database connection
spring.datasource.url = jdbc:mysql://localhost/dao
spring.datasource.username = root
spring.datasource.driverClassName = com.mysql.jdbc.Driver
spring.datasource.password = 

# Specify the DBMS
spring.jpa.database = MYSQL

# Show or not log for each sql query
spring.jpa.show-sql = true

# Hibernate settings are prefixed with spring.jpa.hibernate.*
spring.jpa.hibernate.ddl-auto = update
spring.jpa.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect
spring.jpa.hibernate.naming_strategy = org.hibernate.cfg.ImprovedNamingStrategy   

我收到此错误:

 Caused by: 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.
at org.springframework.boot.autoconfigure.jdbc.DataSourceProperties.getDriverClassName(DataSourceProperties.java:137)
at org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration$NonEmbeddedConfiguration.dataSource(DataSourceAutoConfiguration.java:117)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiat   e(SimpleInstantiationStrategy.java:162)
... 40 more

数据源配置有问题吗?

2 个答案:

答案 0 :(得分:1)

DataSourceProperties.getDriverClassName()方法中引发错误。在弹簧分布中找到相同的源代码:

if (!StringUtils.hasText(driverClassName)) {
    throw new BeanCreationException(
        "Cannot determine embedded database driver class for database type "
            + this.embeddedDatabaseConnection
            + ". If you want an embedded "
            + "database please put a supported one on the classpath.");
}

spring.datasource.driverClassName属性为空时,Spring会抛出此错误。因此,要修复此错误,请确保application.properties位于类路径中。

答案 1 :(得分:0)

我遇到了同样的错误,我的问题是application.properties没有打包在 罐子,我没有在启动时提供它。

如果您正在使用java -jar启动you-jar-name.jar,请确保application.properties可用。根据文档:

SpringApplication将从以下位置的application.properties文件加载属性,并将它们添加到Spring环境中:

当前目录的A / config子目录。 当前目录 一个classpath / config包 类路径根

http://docs.spring.io/spring-boot/docs/current/reference/html/boot-features-external-config.html#boot-features-external-config-application-property-files