快速搭建Spring Boot+MyBatis的項(xiàng)目IDEA(附源碼下載)
如何快速構(gòu)建一個(gè)Spring Boot的項(xiàng)目工具 ideaJDK版本 1.8Spring Boot 版本 1.5.9環(huán)境搭建實(shí)現(xiàn):最基礎(chǔ)前端可以訪問到數(shù)據(jù)庫(kù)內(nèi)的內(nèi)容
開始
1.IDEA 內(nèi)部新建一個(gè)項(xiàng)目,項(xiàng)目類型選擇Spring Initializr,Project SDK選擇適合你當(dāng)前環(huán)境的版本,這里我選擇的是1.8(Spring Boot 2.0以上的版本,JDK選擇請(qǐng)選擇1.8即以上版本),構(gòu)建服務(wù)選擇默認(rèn)就好,點(diǎn)擊Next
2.填寫Group和Artifact(此處我使用的是默認(rèn),請(qǐng)根據(jù)實(shí)際情況填寫),項(xiàng)目類型選擇Maven項(xiàng)目,語言選擇Java,打包類型選擇Jar(SpringBoot內(nèi)置Tomcat,web項(xiàng)目可以直接以Jar包的方式運(yùn)行),Java 版本選擇8,Name自己填寫,Next
3. 選擇Spring Boot的版本,這里先隨便選一個(gè),我們稍后在pom文件中進(jìn)行更改,
在下面的可以選擇相應(yīng)的starter包,我們可以在此處快速選擇,也可以等到pom文件中再手動(dòng)添加。我們選擇最常用的最基本的幾個(gè):Spring bootDevTools:實(shí)現(xiàn)熱部署,Lombok:使用Lombok的注釋,Spring Web,Mybatis和MySQL驅(qū)動(dòng),選擇完畢后,Next
4. 選擇項(xiàng)目保存的名稱和路徑,然后Finish
5.等待項(xiàng)目下載完成,下面的讀條全部完成后,我們就可以點(diǎn)開項(xiàng)目查看項(xiàng)目的結(jié)構(gòu)是否完整
打開pom.xml文件,修改spring boot的版本為1.5.9,修改mybstis依賴的版本為1.3.1,我們使用阿里的Druid數(shù)據(jù)庫(kù)連接池,添加Druid依賴,我是用的mysql為8.0,spring boot1.5.9默認(rèn)的連接驅(qū)動(dòng)是5.*的,修改驅(qū)動(dòng)版本為8.0.11(在pom源碼中列出)
在spring boot maven plugin中添加如下配置,不配置fork無法進(jìn)行熱部署
pom.xml
<?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>1.5.9.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.example</groupId> <artifactId>demo</artifactId> <version>0.0.1-SNAPSHOT</version> <name>demo</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-web</artifactId> </dependency> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.3.1</version> </dependency> <!--Druid 數(shù)據(jù)庫(kù)連接池--> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId>
8.開始配置項(xiàng)目,我們選擇使用yum文件進(jìn)行配置,在resources文件夾下新建application.yml,刪除原來的application.properties,在yum文件中配置下面的內(nèi)容,此處使用的為8.0的Mysql,8.0以下版本請(qǐng)修改連接驅(qū)動(dòng)的名稱
# 配置數(shù)據(jù)庫(kù)連接 8.0 spring: datasource: # =====================MySQL相關(guān)配置===================== # 數(shù)據(jù)庫(kù)類型 name: mysql #數(shù)據(jù)庫(kù)連接驅(qū)動(dòng) driver-class-name: com.mysql.cj.jdbc.Driver #數(shù)據(jù)庫(kù)連接url url: jdbc:mysql://127.0.0.1:3306/數(shù)據(jù)庫(kù)名?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8&useSSL=false #數(shù)據(jù)庫(kù)連接賬號(hào) username: root #數(shù)據(jù)庫(kù)連接密碼 password: root #使用druid數(shù)據(jù)源 type: com.alibaba.druid.pool.DruidDataSource #==================druid相關(guān)配置========================================= druid: #監(jiān)控統(tǒng)計(jì)用的filter:stat 日志用filter:log4j 防御sql注入用filter:wall filters: stat,log4j,wall #最大鏈接數(shù)量 max-active: 20 #初始化時(shí)建立物理連接的個(gè)數(shù) 初始化發(fā)生在顯示調(diào)用init() 或者第一次getConnection時(shí) initial-size: 1 #獲取連接時(shí)的最大等待時(shí)間 毫秒 max-wait: 60000 #最小連接池?cái)?shù)量 min-idle: 1 time-between-eviction-runs-millis: 60000 #鏈接保持空閑而不被驅(qū)逐的最長(zhǎng)時(shí)間 min-evictable-idle-time-millis: 300000 #用來檢驗(yàn)連接是否有效的sql mysql為select 1 # 如果validationQuery為null,testOnBorrow、testOnReturn、testWhileIdle都不會(huì)其作用 validation-query: select 1 # 申請(qǐng)連接的時(shí)候檢測(cè),如果空閑時(shí)間大于timeBetweenEvictionRunsMillis,執(zhí)行validationQuery檢測(cè)連接是否有效 test-while-idle: true # 申請(qǐng)連接時(shí)執(zhí)行validationQuery檢測(cè)連接是否有效,做了這個(gè)配置會(huì)降低性能 test-on-borrow: false # 歸還連接時(shí)執(zhí)行validationQuery檢測(cè)連接是否有效,做了這個(gè)配置會(huì)降低性能 test-on-return: false # 歸還連接時(shí)執(zhí)行validationQuery檢測(cè)連接是否有效,做了這個(gè)配置會(huì)降低性能 pool-prepared-statements: false # 要啟用PSCache,必須配置大于0,當(dāng)大于0時(shí),poolPreparedStatements自動(dòng)觸發(fā)修改為true max-open-prepared-statements: -1 # ====================mybatis============================== mybatis: #配置mybatis的mapper xml文件映射 mapper-locations: classpath*:mapper/*.xml #配置pojo映射 type-aliases-package: com.example.demo.pojo #服務(wù)端口 server: port: 8080
9.創(chuàng)建如下包(config,controller,dao,pojo,service,mapper)
10.在config下創(chuàng)建DruidConfig
DruidConfig
package com.example.demo.config; import com.alibaba.druid.pool.DruidDataSource; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import javax.sql.DataSource; //標(biāo)記這是一個(gè)配置類 @Configuration public class DruidConfig { //配置Druid的Bean 讀取yml配置中spring.datasource為前綴的配置 @ConfigurationProperties(prefix = "spring.datasource") @Bean public DataSource druid(){ return new DruidDataSource(); } }
11.測(cè)試表結(jié)構(gòu)如下:
12.創(chuàng)建pojo,使用lombok的注解生成get和set方法
package com.example.demo.pojo; import lombok.Getter; import lombok.Setter; import java.io.Serializable; @Setter @Getter public class FtbAdmin implements Serializable { private Integer id; private String username; private String password; }
13.在dao下創(chuàng)建mapper接口(別忘了打上mapper注解),在resources/mapper下創(chuàng)建xml文件
mapper接口
package com.example.demo.dao; import com.example.demo.pojo.FtbAdmin; import org.apache.ibatis.annotations.Mapper; import java.util.List; /** * @author 11699 * @date 2020/2/15 - 13:04 */ @Mapper public interface FtbAdminMapper { public List<FtbAdmin> findAll(); }
mapper.xml
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" > <mapper namespace="com.example.demo.dao.FtbAdminMapper" > <resultMap id="BaseResultMap" type="com.example.demo.pojo.FtbAdmin" > <id column="id" property="id" jdbcType="INTEGER" /> <result column="username" property="username" jdbcType="VARCHAR" /> <result column="password" property="password" jdbcType="VARCHAR" /> </resultMap> <select id="findAll" resultMap="BaseResultMap"> select * from ftb_admin </select> </mapper>
14.在service包下創(chuàng)建service接口,在此包下新建impl包,創(chuàng)建service的實(shí)現(xiàn)類(別忘記打上service注解)
service接口
package com.example.demo.service; import com.example.demo.pojo.FtbAdmin; import java.util.List; /** * @author 11699 * @date 2020/2/15 - 13:14 * */ public interface FtbAdminService { public List<FtbAdmin> findAll(); }
service實(shí)現(xiàn)類
package com.example.demo.service.impl; import com.example.demo.dao.FtbAdminMapper; import com.example.demo.pojo.FtbAdmin; import com.example.demo.service.FtbAdminService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.List; /** * @author 11699 * @date 2020/2/15 - 13:16 * * 服務(wù)層實(shí)現(xiàn),不要忘記打上service注解 */ @Service public class FtbAdminServiceImpl implements FtbAdminService { //注入mapper @Autowired private FtbAdminMapper adminMapper; @Override public List<FtbAdmin> findAll() { return adminMapper.findAll(); } }
在controller包下創(chuàng)建controller類
package com.example.demo.controller; import com.example.demo.pojo.FtbAdmin; import com.example.demo.service.FtbAdminService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import java.util.List; /** * @author 11699 * @date 2020/2/15 - 13:29 * * @RestController:返回整個(gè)controller返回的都是json字符串 * @RequestMapping("/admin"):請(qǐng)求映射 */ @RestController @RequestMapping("/admin") public class FtbAdminController { //注入服務(wù)層 @Autowired private FtbAdminService adminService; //添加映射 無需與方法名一樣 @RequestMapping("/findAll") public List<FtbAdmin> findAll(){ return adminService.findAll(); } }
在spring boot啟動(dòng)類添加mapper自動(dòng)掃描注解
package com.example.demo; import org.mybatis.spring.annotation.MapperScan; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; //開啟mapper接口掃描,指定掃描基礎(chǔ)包 @MapperScan(basePackages = "com.example.demo.dao") @SpringBootApplication public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } }
運(yùn)行,在springboot啟動(dòng)類的main方法上運(yùn)行
18 啟動(dòng)沒有報(bào)錯(cuò)的話,我們可以開始測(cè)試了在瀏覽器中輸入地址↓
http://localhost:8080/admin/findAll
OK,到此為止,我們就完成了?。?!
附上項(xiàng)目的完整結(jié)構(gòu)
到此這篇關(guān)于快速搭建Spring Boot+MyBatis的項(xiàng)目IDEA(附源碼下載)的文章就介紹到這了,更多相關(guān)Spring Boot+MyBatis的項(xiàng)目IDEA內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
IntelliJ IDEA 設(shè)置代碼提示或自動(dòng)補(bǔ)全的快捷鍵功能
這篇文章主要介紹了IntelliJ IDEA 設(shè)置代碼提示或自動(dòng)補(bǔ)全的快捷鍵功能,需要的朋友可以參考下2018-03-03Maven配置文件修改及導(dǎo)入第三方j(luò)ar包的實(shí)現(xiàn)
本文主要介紹了Maven配置文件修改及導(dǎo)入第三方j(luò)ar包的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08Java實(shí)現(xiàn)發(fā)送短信驗(yàn)證碼+redis限制發(fā)送的次數(shù)功能
這篇文章主要介紹了Java實(shí)現(xiàn)發(fā)送短信驗(yàn)證碼+redis限制發(fā)送的次數(shù),本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-04-04簡(jiǎn)單理解遵循接口隔離原則的Java設(shè)計(jì)模式編程
這篇文章主要介紹了遵循接口隔離原則的Java設(shè)計(jì)模式編程,針對(duì)Java編程中interface接口方面的編寫進(jìn)行約束,需要的朋友可以參考下2016-02-02基于eclipse-temurin鏡像部署spring boot應(yīng)用的實(shí)現(xiàn)示例
本文提供了基于eclipse-temurin鏡像部署Spring Boot應(yīng)用的詳細(xì)實(shí)現(xiàn)示例,通過使用Docker鏡像,可以輕松地創(chuàng)建和管理Spring Boot應(yīng)用程序的容器化環(huán)境,感興趣的可以了解一下2023-08-08Java多線程開發(fā)工具之CompletableFuture的應(yīng)用詳解
做Java編程,難免會(huì)遇到多線程的開發(fā),但是JDK8這個(gè)CompletableFuture類很多開發(fā)者目前還沒聽說過,但是這個(gè)類實(shí)在是太好用了,本文就來聊聊它的應(yīng)用吧2023-03-03MyBatis中使用foreach循環(huán)的坑及解決
這篇文章主要介紹了MyBatis中使用foreach循環(huán)的坑及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01SpringBoot?中使用?Validation?校驗(yàn)參數(shù)的方法詳解
Validation?是用于檢查程序代碼中參數(shù)的有效性的框架,作為?Spring?框架中的一個(gè)參數(shù)校驗(yàn)工具,集成在?spring-context?包中,這篇文章主要介紹了SpringBoot?中使用?Validation?校驗(yàn)參數(shù),需要的朋友可以參考下2022-05-05