2015-10-12 4 views
5

Ich weiß, dass der Frühling Stiefel einen dataSource Bean automatisch erstellt werden, wenn im Zusammenhang Konfigurationen in application.properties eingestellt sind, wie:Warum kann die DataSource in der Spring Boot-Anwendung nicht automatisch gestartet werden?

spring.datasource.url = jdbc:mysql://192.168.10.103:3306/hms?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull 
spring.datasource.username=root 
[email protected] 
spring.datasource.driver-class-name=com.mysql.jdbc.Driver 

Code Anwendung:

package com.synline.mdataserver; 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.boot.CommandLineRunner; 
import org.springframework.boot.SpringApplication; 
import org.springframework.boot.autoconfigure.SpringBootApplication; 
import org.springframework.context.annotation.AnnotationConfigApplicationContext; 
import org.apache.tomcat.jdbc.pool.DataSource; 

@SpringBootApplication 
public class Application implements CommandLineRunner { 

    @Autowired 
    AnnotationConfigApplicationContext context; 

    /*@Autowired 
    DataSource dataSource;*/ 

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

    @Override 
    public void run(String... args) throws Exception { 
     DataSource dataSource = (DataSource)context.getBean("dataSource"); 
     System.out.println(dataSource); 

     while (true) { 
      Thread.sleep(5000); 
     } 

    } 
} 

Wenn der @Autowired Datasource Kommentar gesetzt wird, die Bean Informationen werden gedruckt:

[email protected]{ConnectionPool[defaultAutoCommit=null; defaultReadOnly=null; ....} 

Also ich denke Spring Boot reall Du hast die Bean erstellt.

Aber wenn @Autowried Datasource verwendet wird, Ausnahme auftritt sollte als Standard-JDBC-Datasource (das heißt javax.sql.DataSource) deklariert werden No Such Bean

Error creating bean with name 'application': Injection of autowired dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Could not autowire field: org.apache.tomcat.jdbc.pool.DataSource com.synline.mdataserver.Application.dataSource; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [org.apache.tomcat.jdbc.pool.DataSource] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)} 
+0

Bitte posten Sie den ganzen Fall, der nicht funktioniert, nicht nur ein Schnipsel. Außerdem sollten Sie eine 'javax.sql.DataSource' verwenden, nicht den spezifischen Tomcat-Typ. –

+0

Danke. Ich bearbeite den Beitrag und füge den vollständigen Code hinzu. –

+0

Ah, Deinum, Sie verstehen es. Nachdem ich "javax.sql.DataSource" statt "import.org.apache.tomcat.jdbc.pool.DataSource;" importiere, keine Probleme mehr! –

Antwort

4

Ihre Variable zu beschweren, nicht als eine bestimmte Implementierung dieser Schnittstelle.

+0

Ja, das ist die Ursache. Vielen Dank! –

Verwandte Themen