2014-04-25 29 views
11

Pomyślałem, że udało mi się stworzyć prototyp używając Spring Boot 1.0.2.RELEASE (był 1.0.1.RELEASE do dzisiaj).Spring boot nie wczytuje DataSource za pomocą sterownika PostgreSQL

Mam szukał i szukał i próbował rozwiązań takich jak: Spring Boot jdbc datasource autoconfiguration fails on standalone tomcat Spring Boot/Spring Data import.sql doesn't run Spring-Boot-1.0.0.RC1

Wszyscy sugeruje niech Wiosna Boot wykonać zadanie. Podczas korzystania H2, wszystko działa, ale gdy próbuję przełączyć do PostgreSQL, otrzymuję:

Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/autoconfigure/orm/jpa/HibernateJpaAutoConfiguration.class]: Instantiation of bean failed; nested exception is org.springframework.beans.factory.BeanDefinitionStoreException: Factory method [public org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean org.springframework.boot.autoconfigure.orm.jpa.JpaBaseConfiguration.entityManagerFactory(org.springframework.orm.jpa.JpaVendorAdapter)] threw exception; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [javax.sql.DataSource] is defined 

Moja build.gradle jest następująca:

loadConfiguration() 

def loadConfiguration() { 
def environment = hasProperty('env') ? env : 'dev' 
project.ext.envrionment = environment 
println "Environment is set to $environment" 

def configFile = file('config.groovy') 
def config = new ConfigSlurper("$environment").parse(configFile.toURL()) 
project.ext.config = config 
} 

buildscript { 
ext { 
    springBootVersion = '1.0.2.RELEASE' 
} 
repositories { 
    mavenCentral() 
} 
dependencies { 
    classpath("org.springframework.boot:spring-boot-gradle- plugin:${springBootVersion}") 
} 
} 

apply plugin: 'java' 
apply plugin: 'eclipse' 
apply plugin: 'idea' 
apply plugin: 'spring-boot' 
apply plugin: 'war' 
apply plugin: 'groovy' 

war { 
baseName = 'test' 
version = '0.0.1-SNAPSHOT' 
} 

configurations { 
providedRuntime 
} 

repositories { 
mavenCentral() 
} 

dependencies { 
compile("org.springframework.boot:spring-boot-starter-web:${springBootVersion}") 
compile("org.springframework.boot:spring-boot-starter-thymeleaf:${springBootVersion}") 

compile("org.springframework.boot:spring-boot-starter-jdbc:${springBootVersion}") 
compile("org.springframework.boot:spring-boot-starter-data-jpa:${springBootVersion}") 
compile("postgresql:postgresql:9.1-901.jdbc4") 
//compile("com.h2database:h2") 

testCompile("org.springframework.boot:spring-boot-starter-test:${springBootVersion}") 

} 

task wrapper(type: Wrapper) { 
gradleVersion = '1.11' 
} 

application.properties:

spring.jpa.database=POSTGRESQL 
spring.jpa.show-sql=false 
spring.jpa.hibernate.ddl-auto=update 

spring.database.driverClassName=org.postgresql.Driver 
spring.datasource.url=jdbc:postgresql://localhost/cms 
spring.datasource.username=cms 
spring.datasource.password=NA 

Usuwanie pliku application.properties i zmiana zależności z powrotem na H2 i wszystko jest w porządku.

nie mogę znaleźć gdzie robie źle :-(

Odpowiedz

16

Skąd się to wzięło? database.driverClassName=org.postgresql.Driver Czy nie myśli spring.datasource.driverClassName

+0

Absolutnie Copy-n-paste typo Pytanie aktualizowane?.! Dziękujemy! – mamruoc

+0

CO TYPO MISTAKE! Ok, źródło danych, a nie baza danych * westchnienie * – mamruoc