SpringBoot整合Mybatis與druid實(shí)現(xiàn)流程詳解
SpringBoot整合junit
SpringBoot整合junit
①還是一樣,我們首先創(chuàng)建一個(gè)SpringBoot模塊。
由于我們并不測(cè)試前端,而只是整合junit,所以不用選擇模板,選擇其中的web即可。
完成以后我們打開Pom.xml,會(huì)發(fā)現(xiàn)報(bào)錯(cuò),這里我的版本不能到2.7.5,降版本。
②導(dǎo)入對(duì)應(yīng)的starter
查看Pom.xml文件:我們發(fā)現(xiàn)已經(jīng)有了一個(gè)Spring-Boot-stater-test,這其實(shí)就是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,那我們還整合啥?答案是不用整合!
因?yàn)镾pringBoot項(xiàng)目在創(chuàng)建的時(shí)候已經(jīng)默認(rèn)整合了junit,至于為什么是這樣,是因?yàn)镾pringBoot是一個(gè)maven項(xiàng)目,而maven在執(zhí)行它的生命周期的時(shí)候測(cè)試是跳不過去的,它必須執(zhí)行測(cè)試。
③測(cè)試類添加@SpringBootTest注解修飾
package com.example; import org.junit.jupiter.api.Test; import org.springframework.boot.test.context.SpringBootTest; @SpringBootTest class SpringBootJuintApplicationTests { @Test void contextLoads() { } }
④ 使用自動(dòng)裝配添加要測(cè)試的對(duì)象
這里測(cè)試啥呢?測(cè)試一下dao層
一、編寫Dao層接口:
package com.example.Dao; public interface UserDao { public void selectAll(); }
二、編寫Dao層接口的實(shí)現(xiàn)類:值得說明的是,一般情況下,因?yàn)镈ao層的mapper需要用到反射,一般是沒有實(shí)現(xiàn)類的,這里只是為了測(cè)試方便?。?!
package com.example.Dao.impl; import com.example.Dao.UserDao; import org.springframework.stereotype.Repository; @Repository//把這個(gè)類交給Spring容器管理 public class ImplUserDao implements UserDao { @Override public void selectAll() { System.out.println("selectAll......."); } }
三、在測(cè)試類中使用@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í)行測(cè)試
SpringBoot整合junit的classes
在上面整合的junit并不完整,為什么這樣說,請(qǐng)看:
現(xiàn)在SpringBoot的引導(dǎo)類和測(cè)試類的引導(dǎo)類都在同級(jí)目錄下,現(xiàn)在我要把測(cè)試類的引導(dǎo)類移動(dòng)到com包下
執(zhí)行測(cè)試,輸出:Unable to find a @SpringBootConfiguration, you need to use @ContextConfiguration or @SpringBootTest(classes=...) with your test
:說的是它找不到SpringBoot的配置類,需要你使用@ContextConfiguration或者@SpringBootTest為你的測(cè)試類指定SpringBoot的配置類
為什么出現(xiàn)以下情況,原來是@SpringBootTest會(huì)默認(rèn)從當(dāng)前包及其子包下尋找SpringBoot的配置類,當(dāng)我們把測(cè)試類中的SpringBootJuintApplicationTests移動(dòng)到com包下時(shí),它就找不到對(duì)應(yīng)的SpringBoot的配置類,因?yàn)樗@時(shí)不在引導(dǎo)類包及其子包下,也就無法從spring容器中獲取對(duì)應(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)建工程、新建對(duì)應(yīng)實(shí)體類
SpringBoot方便的一部分原因就是,用什么導(dǎo)入就勾選什么技術(shù)。
或者手動(dòng)加入:
<?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-Mybatis</artifactId> <version>0.0.1-SNAPSHOT</version> <name>SpringBoot-Mybatis</name> <description>SpringBoot-Mybatis</description> <properties> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.2.2</version> </dependency> <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.21</version> </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>
創(chuàng)建實(shí)體類對(duì)象:
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)入了對(duì)應(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(); }
三、編寫測(cè)試
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()); } }
測(cè)試:
報(bào)了以上兩個(gè)錯(cuò)誤,這是我們希望看到的,為什么?
原因:在上面的驅(qū)動(dòng)中我們使用的是MySQL 8.X版本的,在8及以上的MySQL驅(qū)動(dòng)中,SpringBoot強(qiáng)制我們進(jìn)行時(shí)區(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: ******
測(cè)試:
值得注意的是:在MySQL8才需要設(shè)置時(shí)區(qū)和使用cj.jdbc.
SpringBoot 整合druid
配置前置知識(shí)小點(diǎn)
因?yàn)閐ruid是一個(gè)連接池,需要提供數(shù)據(jù)源,測(cè)試也還是那一套,這里直接復(fù)制上邊的模塊進(jìn)行重新開發(fā)。
整合druid
首先,我們應(yīng)該知道的是,SpringBoot之所以好用,就是因?yàn)樗梢院芎玫恼掀渌牡谌劫Y源和技術(shù),核心就是:導(dǎo)入對(duì)應(yīng)的stater,根據(jù)配置格式,編寫非默認(rèn)值對(duì)應(yīng)的配置項(xiàng)
一、導(dǎo)入對(duì)應(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: ******
三、測(cè)試
測(cè)試?配置完成了?完成了,SpringBoot就是這么好用
到此這篇關(guān)于SpringBoot整合Mybatis與druid實(shí)現(xiàn)流程詳解的文章就介紹到這了,更多相關(guān)SpringBoot整合Mybatis與druid內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java編程生產(chǎn)者消費(fèi)者實(shí)現(xiàn)的四種方法
Java生產(chǎn)者和消費(fèi)者問題是線程安全模型中的經(jīng)典問題:生產(chǎn)者和消費(fèi)者在同一個(gè)時(shí)間段共用同一個(gè)存儲(chǔ)空間,生產(chǎn)者向存儲(chǔ)空間中添加產(chǎn)品呢,消費(fèi)者取走產(chǎn)品,當(dāng)存儲(chǔ)空間為空時(shí),消費(fèi)者阻塞,當(dāng)存儲(chǔ)空間滿時(shí),生產(chǎn)者阻塞2021-10-10MyBatis-Plus攔截器實(shí)現(xiàn)數(shù)據(jù)權(quán)限控制的示例
本文主要介紹了MyBatis-Plus攔截器實(shí)現(xiàn)數(shù)據(jù)權(quán)限控制的示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02Java使用OTP動(dòng)態(tài)口令(每分鐘變一次)進(jìn)行登錄認(rèn)證
這篇文章主要介紹了Java使用OTP動(dòng)態(tài)口令(每分鐘變一次)進(jìn)行登錄認(rèn)證,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09java語言基礎(chǔ)之標(biāo)識(shí)符和命名規(guī)則詳解
這篇文章主要給大家介紹了關(guān)于java語言基礎(chǔ)之標(biāo)識(shí)符和命名規(guī)則的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03Springboot整合mybatisplus時(shí),使用條件構(gòu)造器排序報(bào)錯(cuò)問題及解決
這篇文章主要介紹了Springboot整合mybatisplus時(shí),使用條件構(gòu)造器排序報(bào)錯(cuò)問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-04-04Spring Boot通過Junit實(shí)現(xiàn)單元測(cè)試過程解析
這篇文章主要介紹了Spring Boot通過Junit實(shí)現(xiàn)單元測(cè)試過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01Java將文件夾保留目錄打包為 ZIP 壓縮包并下載的教程詳解
這篇文章主要介紹了Java將文件夾保留目錄打包為 ZIP 壓縮包并下載的教程詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08Java中checkbox實(shí)現(xiàn)跨頁多選的方法
最近做了一個(gè)項(xiàng)目其中遇到這樣的需求,要實(shí)現(xiàn)checkbox跨頁多選功能,經(jīng)過小編整理,順利解決,今天小編給大家分享Java中checkbox實(shí)現(xiàn)跨頁多選的方法,需要的的朋友參考下2017-01-01spring關(guān)于組件的注入及獲取流程場(chǎng)景分析
這篇文章主要介紹了spring關(guān)于組件的注入及獲取流程場(chǎng)景分析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-07-07