零基礎IDEA整合SpringBoot + Mybatis項目,及常見問題詳細解答

開發環境介紹:IDEA + maven + springboot2.1.4java

一、用IDEA搭建SpringBoot項目:File - New - Project - Spring Initializr,(在選引用功能界面時,什麼都不選)再一直Next便可,最後生成的項目結構以下:(首先記得在File - Settings - 搜索maven,將maven路徑改爲你本地配置的)mysql

 

而後咱們在SpringBoot啓動文件Sb001Application下,啓動項目,出現 Started Sb001Application in 0.602 seconds (JVM running for 1.117) 說明項目啓動成功!web

 

固然,如今咱們項目幾乎是什麼功能都沒有的,咱們和springMVC同樣,搭建service、serviceImpl、dao、xml文件等,也是能夠正常啓動的,spring

可是:當你嘗試在好比在serviceImpl 用@Autowired 注入dao層接口時,就會報錯:sql

Field accountDao in com.example.demo.service.impl.AccountServiceImpl required a bean of type 'com.example.demo.dao.AccountDao' that could not be found.數據庫

The injection point has the following annotations:
- @org.springframework.beans.factory.annotation.Autowired(required=true)apache

 

正常狀況下,這時你的dao層都是接口interface,項目啓動時,它是沒有被實現的,被注入到別的bean時,天然就會報上面的錯,若是不在別的類裏面用@Autowired 注入dao層有關接口時,啓動也不會報錯!springboot

 

如今咱們經過整合mybatis來實現dao層的接口,來實現數據庫的鏈接:mybatis

第一步:引入jia包app

<dependency>
     <groupId>org.mybatis.spring.boot</groupId>
     <artifactId>mybatis-spring-boot-starter</artifactId>
     <version>2.0.1</version>
</dependency>

Tips:若是嘗試在引入mybatis後,不作任何配置,也就是不在yml文件配置數據庫鏈接信息,直接啓動項目,發現會報錯:

Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could be configured.

Reason: Failed to determine a suitable driver class

 

後來經過百度終於找到答案:spring boot啓動時默認會加載org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration類,DataSourceAutoConfiguration類使用了@Configuration註解向spring注入了dataSource bean。由於工程中沒有關於dataSource相關的配置信息,當spring建立dataSource bean因缺乏相關的信息就會報錯。

解決辦法:

(1)將@SpringBootApplication註解改爲@SpringBootApplication(exclude={DataSourceAutoConfiguration.class}),這種辦法能夠解決上面的報錯,可是會跟咱們想配置mybatis的原意走遠,不推薦【可是,提一句,在配置多數據源時,也是這樣配置的】

(2)第二種辦法就是配置數據庫了,這裏首先將系統resources下默認生成的properties文件刪掉,新建application.yml文件(別問我爲何要用yml,由於的確好用^_^),而且在裏面加入數據源的配置

spring:
  datasource:
    url: jdbc:mysql://172.0.0.0:3306/你的數據庫名稱?serverTimezone=GMT%2B8
    username: 帳號
    password: 密碼
    #driver-class-name: com.mysql.cj.jdbc.Driver #根據mysql版本選擇,通常都是能夠的
    driver-class-name: com.mysql.jdbc.Driver

配置了數據源,接下來就是鏈接數據庫了,那麼就要引入鏈接數據庫的Jar包:

<dependency>
     <groupId>mysql</groupId>
     <artifactId>mysql-connector-java</artifactId>
     <scope>runtime</scope>
</dependency>

配置到這個時候,項目是能夠正常啓動的,可是當你再次嘗試在serviceImpl經過@Autowired 注入dao層的接口時,它又會報bean of type 'com.example.demo.dao.AccountDao' that could not be found.一樣的錯,緣由上面也解釋過,接口沒法實現,,,

那麼如何配置讓mybatis實現咱們dao層的接口呢?

那就是在啓動文件新加 @MapperScan("com.example.demo.dao"),裏面是項目dao包的路徑,必定不能錯!!!,也能夠@MapperScan("com.example.demo.*.dao")這種;如今咱們在serviceImpl經過@Autowired 注入dao層的接口時,項目啓動就正常了!

如今咱們去test目錄下,建立一個測試類,寫一個最簡單的方法getById,固然mybatis是須要在xml裏面寫本身sql的,xml的存放路徑咱們不會用系統默認的,如今咱們指定放在resources下的mybatis包下,新建完mybatis包後,還要在yml文件配置

mybatis:
  mapper-locations: classpath:mybatis/**/*.xml

到這裏,測試類就能夠正常運行,能夠鏈接數據庫讀取數據了!自此,最簡單的配置spring boot + mybatis 就整合完成了!最後咱們對照開始的圖對比一下

最後,附上項目完整的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>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.4.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example</groupId>
    <artifactId>demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>sb001</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <!-- 上面兩個是 零配置 springboot 都會自帶生成的 -->

        <!-- 整合mybatis的最簡配置,web都是能夠不用的 -->
        <!--<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>-->

        <!-- mybatis -->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.0.1</version>
        </dependency>

        <!-- 鏈接Mysql數據庫,別的數據庫的要對應改 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>

    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>
View Code

 和完整的最簡的yml文件配置:

spring:
  datasource:
    url: jdbc:mysql://127.0.0.0:3306/testdb?serverTimezone=GMT%2B8
    username: admin
    password: 123456
    driver-class-name: com.mysql.cj.jdbc.Driver

mybatis:
  mapper-locations: classpath:mybatis/**/*.xml
View Code

雖然用SpringBoot項目很長時間了,當同事「乞丐式」配置一個最簡項目時,遇到各類報錯,解決的過程當中仍是能夠學到不少點的,特地記錄下來,但願能夠幫到一些新手,特別是裏面兩個錯誤的主要緣由,估計不少人都不必定清楚,若是筆者理解有不正確的地方,也請指正!

 

Tips:

(1)會的不難,不會就難

(2)學就會,不學就不會

筆於2019-04-24,月底將結束畢業後工做長達兩年的第一家公司WW,特此記錄

相關文章
相關標籤/搜索