SpringBoot整合Mybatis與druid實現(xiàn)流程詳解
SpringBoot整合junit
SpringBoot整合junit
①還是一樣,我們首先創(chuàng)建一個SpringBoot模塊。

由于我們并不測試前端,而只是整合junit,所以不用選擇模板,選擇其中的web即可。

完成以后我們打開Pom.xml,會發(fā)現(xiàn)報錯,這里我的版本不能到2.7.5,降版本。

②導(dǎo)入對應(yīng)的starter
查看Pom.xml文件:我們發(fā)現(xiàn)已經(jīng)有了一個Spring-Boot-stater-test,這其實就是SpringBoot已經(jīng)自己整合了junit
<?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 https://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.7.4</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>SpringBoot-juint</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>SpringBoot-juint</name>
<description>SpringBoot-juint</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>問題隨之而來,既然SpringBoot已經(jīng)整合了junit,那我們還整合啥?答案是不用整合!
因為SpringBoot項目在創(chuàng)建的時候已經(jīng)默認(rèn)整合了junit,至于為什么是這樣,是因為SpringBoot是一個maven項目,而maven在執(zhí)行它的生命周期的時候測試是跳不過去的,它必須執(zhí)行測試。
③測試類添加@SpringBootTest注解修飾
package com.example;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest
class SpringBootJuintApplicationTests {
@Test
void contextLoads() {
}
}④ 使用自動裝配添加要測試的對象
這里測試啥呢?測試一下dao層
一、編寫Dao層接口:
package com.example.Dao;
public interface UserDao {
public void selectAll();
}二、編寫Dao層接口的實現(xiàn)類:值得說明的是,一般情況下,因為Dao層的mapper需要用到反射,一般是沒有實現(xiàn)類的,這里只是為了測試方便?。?!
package com.example.Dao.impl;
import com.example.Dao.UserDao;
import org.springframework.stereotype.Repository;
@Repository//把這個類交給Spring容器管理
public class ImplUserDao implements UserDao {
@Override
public void selectAll() {
System.out.println("selectAll.......");
}
}三、在測試類中使用@Autowired進(jìn)行注入
package com.example;
import com.example.Dao.UserDao;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest
class SpringBootJuintApplicationTests {
@Autowired
UserDao userDao;
@Test
void contextLoads() {
userDao.selectAll();
}
}四、執(zhí)行測試

SpringBoot整合junit的classes
在上面整合的junit并不完整,為什么這樣說,請看:

現(xiàn)在SpringBoot的引導(dǎo)類和測試類的引導(dǎo)類都在同級目錄下,現(xiàn)在我要把測試類的引導(dǎo)類移動到com包下
執(zhí)行測試,輸出:Unable to find a @SpringBootConfiguration, you need to use @ContextConfiguration or @SpringBootTest(classes=...) with your test
:說的是它找不到SpringBoot的配置類,需要你使用@ContextConfiguration或者@SpringBootTest為你的測試類指定SpringBoot的配置類
為什么出現(xiàn)以下情況,原來是@SpringBootTest會默認(rèn)從當(dāng)前包及其子包下尋找SpringBoot的配置類,當(dāng)我們把測試類中的SpringBootJuintApplicationTests移動到com包下時,它就找不到對應(yīng)的SpringBoot的配置類,因為它這時不在引導(dǎo)類包及其子包下,也就無法從spring容器中獲取對應(yīng)bean,則無法進(jìn)行注入。
解決方法:在@SpringBootTest注解中指定引導(dǎo)類或者使用@ContextConfiguration
@SpringBootTest(classes = SpringBootJuintApplication.class) @ContextConfiguration(classes = SpringBootJuintApplication.class)

SpringBoot整合Mybatis
整合前的準(zhǔn)備
值得說明的是,這里整合Mybatis用的是注解的方式
一、創(chuàng)建數(shù)據(jù)庫數(shù)據(jù)
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
`username` varchar(20) CHARACTER SET utf8 COLLATE utf8_esperanto_ci NULL DEFAULT NULL,
`password` varchar(20) CHARACTER SET utf8 COLLATE utf8_esperanto_ci NULL DEFAULT NULL
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_esperanto_ci ROW_FORMAT = Dynamic;
INSERT INTO `user` VALUES ('zhangsan', '775033');
INSERT INTO `user` VALUES ('lisi', '330678');
SET FOREIGN_KEY_CHECKS = 1;
二、創(chuàng)建工程、新建對應(yīng)實體類
SpringBoot方便的一部分原因就是,用什么導(dǎo)入就勾選什么技術(shù)。

或者手動加入:
創(chuàng)建實體類對象:
package com.example.entity;
public class User {
private String username;
private String password;
@Override
public String toString() {
return "User{" +
"username='" + username + '\'' +
", password='" + password + '\'' +
'}';
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public User() {
}
public User(String username, String password) {
this.username = username;
this.password = password;
}
}整合Mybatis
一、上面已經(jīng)導(dǎo)入了對應(yīng)技術(shù)用到的坐標(biāo),現(xiàn)在要配置數(shù)據(jù)源,在哪配置呢,在SpringBoot的配置文件:
spring:
datasource:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/springboot
username: root
password: ******
二、編寫dao層接口()
package com.example.dao;
import com.example.entity.User;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
import java.util.List;
@Mapper
public interface UserDao {
@Select("select username,password from user")
public List<User> selectAll();
}三、編寫測試
package com.example.springbootmybatis;
import com.example.dao.UserDao;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest
class SpringBootMybatisApplicationTests {
@Autowired
UserDao userDao;
@Test
void contextLoads() {
System.out.println(userDao.selectAll());
}
}測試:


報了以上兩個錯誤,這是我們希望看到的,為什么?
原因:在上面的驅(qū)動中我們使用的是MySQL 8.X版本的,在8及以上的MySQL驅(qū)動中,SpringBoot強(qiáng)制我們進(jìn)行時區(qū)設(shè)置,并且要用:com.mysql.cj.jdbc.Driver
解決:這里我們只需要在配置文件中添加失去設(shè)置和更改Driver即可
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/springboot?serverTimezone=UTC
username: root
password: ******
測試:

值得注意的是:在MySQL8才需要設(shè)置時區(qū)和使用cj.jdbc.
SpringBoot 整合druid
配置前置知識小點(diǎn)
因為druid是一個連接池,需要提供數(shù)據(jù)源,測試也還是那一套,這里直接復(fù)制上邊的模塊進(jìn)行重新開發(fā)。
整合druid
首先,我們應(yīng)該知道的是,SpringBoot之所以好用,就是因為它可以很好的整合其他的第三方資源和技術(shù),核心就是:導(dǎo)入對應(yīng)的stater,根據(jù)配置格式,編寫非默認(rèn)值對應(yīng)的配置項
一、導(dǎo)入對應(yīng)druid的stater
<!-- https://mvnrepository.com/artifact/com.alibaba/druid-spring-boot-starter -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.2.8</version>
</dependency>二、在配置文件中配置數(shù)據(jù)源
spring:
datasource:
druid:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/springboot?serverTimezone=UTC
username: root
password: ******
三、測試
測試?配置完成了?完成了,SpringBoot就是這么好用

到此這篇關(guān)于SpringBoot整合Mybatis與druid實現(xiàn)流程詳解的文章就介紹到這了,更多相關(guān)SpringBoot整合Mybatis與druid內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java連接Oracle數(shù)據(jù)庫完整步驟記錄
數(shù)據(jù)庫的操作是當(dāng)前系統(tǒng)開發(fā)必不可少的開發(fā)部分之一,下面這篇文章主要給大家介紹了關(guān)于Java連接Oracle數(shù)據(jù)庫的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01
SpringBoot(cloud)自動裝配bean找不到類型的問題
這篇文章主要介紹了SpringBoot(cloud)自動裝配bean找不到類型的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-02-02
SpringBoot?使用定時任務(wù)(SpringTask)的詳細(xì)步驟
Cron?表達(dá)式非常靈活,可以滿足各種定時任務(wù)的需求,但需要注意的是,Cron?表達(dá)式只能表示固定的時間點(diǎn),無法處理復(fù)雜的時間邏輯,本文給大家介紹SpringBoot?使用定時任務(wù)(SpringTask)的詳細(xì)步驟,感興趣的朋友一起看看吧2024-02-02

