快速搭建Spring Boot+MyBatis的項目IDEA(附源碼下載)
如何快速構建一個Spring Boot的項目工具 ideaJDK版本 1.8Spring Boot 版本 1.5.9環境搭建實現:最基礎前端可以訪問到數據庫內的內容
開始
1.IDEA 內部新建一個項目,項目類型選擇Spring Initializr,Project SDK選擇適合你當前環境的版本,這里我選擇的是1.8(Spring Boot 2.0以上的版本,JDK選擇請選擇1.8即以上版本),構建服務選擇默認就好,點擊Next
2.填寫Group和Artifact(此處我使用的是默認,請根據實際情況填寫),項目類型選擇Maven項目,語言選擇Java,打包類型選擇Jar(SpringBoot內置Tomcat,web項目可以直接以Jar包的方式運行),Java 版本選擇8,Name自己填寫,Next
3. 選擇Spring Boot的版本,這里先隨便選一個,我們稍后在pom文件中進行更改,在下面的可以選擇相應的starter包,我們可以在此處快速選擇,也可以等到pom文件中再手動添加。我們選擇最常用的最基本的幾個:Spring bootDevTools:實現熱部署,Lombok:使用Lombok的注釋,Spring Web,Mybatis和MySQL驅動,選擇完畢后,Next
4. 選擇項目保存的名稱和路徑,然后Finish
5.等待項目下載完成,下面的讀條全部完成后,我們就可以點開項目查看項目的結構是否完整
打開pom.xml文件,修改spring boot的版本為1.5.9,修改mybstis依賴的版本為1.3.1,我們使用阿里的Druid數據庫連接池,添加Druid依賴,我是用的mysql為8.0,spring boot1.5.9默認的連接驅動是5.*的,修改驅動版本為8.0.11(在pom源碼中列出)
在spring boot maven plugin中添加如下配置,不配置fork無法進行熱部署
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 數據庫連接池--> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId>
8.開始配置項目,我們選擇使用yum文件進行配置,在resources文件夾下新建application.yml,刪除原來的application.properties,在yum文件中配置下面的內容,此處使用的為8.0的Mysql,8.0以下版本請修改連接驅動的名稱
# 配置數據庫連接 8.0spring: datasource: # =====================MySQL相關配置===================== # 數據庫類型 name: mysql #數據庫連接驅動 driver-class-name: com.mysql.cj.jdbc.Driver #數據庫連接url url: jdbc:mysql://127.0.0.1:3306/數據庫名?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8&useSSL=false #數據庫連接賬號 username: root #數據庫連接密碼 password: root #使用druid數據源 type: com.alibaba.druid.pool.DruidDataSource #==================druid相關配置========================================= druid: #監控統計用的filter:stat 日志用filter:log4j 防御sql注入用filter:wall filters: stat,log4j,wall #最大鏈接數量 max-active: 20 #初始化時建立物理連接的個數 初始化發生在顯示調用init() 或者第一次getConnection時 initial-size: 1 #獲取連接時的最大等待時間 毫秒 max-wait: 60000 #最小連接池數量 min-idle: 1 time-between-eviction-runs-millis: 60000 #鏈接保持空閑而不被驅逐的最長時間 min-evictable-idle-time-millis: 300000 #用來檢驗連接是否有效的sql mysql為select 1 # 如果validationQuery為null,testOnBorrow、testOnReturn、testWhileIdle都不會其作用 validation-query: select 1 # 申請連接的時候檢測,如果空閑時間大于timeBetweenEvictionRunsMillis,執行validationQuery檢測連接是否有效 test-while-idle: true # 申請連接時執行validationQuery檢測連接是否有效,做了這個配置會降低性能 test-on-borrow: false # 歸還連接時執行validationQuery檢測連接是否有效,做了這個配置會降低性能 test-on-return: false # 歸還連接時執行validationQuery檢測連接是否有效,做了這個配置會降低性能 pool-prepared-statements: false # 要啟用PSCache,必須配置大于0,當大于0時,poolPreparedStatements自動觸發修改為true max-open-prepared-statements: -1# ====================mybatis==============================mybatis: #配置mybatis的mapper xml文件映射 mapper-locations: classpath*:mapper/*.xml #配置pojo映射 type-aliases-package: com.example.demo.pojo#服務端口server: port: 8080
9.創建如下包(config,controller,dao,pojo,service,mapper)
10.在config下創建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;//標記這是一個配置類@Configurationpublic class DruidConfig { //配置Druid的Bean 讀取yml配置中spring.datasource為前綴的配置 @ConfigurationProperties(prefix = 'spring.datasource') @Bean public DataSource druid(){ return new DruidDataSource(); }}
11.測試表結構如下:
12.創建pojo,使用lombok的注解生成get和set方法
package com.example.demo.pojo;import lombok.Getter;import lombok.Setter;import java.io.Serializable;@Setter@Getterpublic class FtbAdmin implements Serializable { private Integer id; private String username; private String password;}
13.在dao下創建mapper接口(別忘了打上mapper注解),在resources/mapper下創建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 */@Mapperpublic 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 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 resultMap='BaseResultMap'> select * from ftb_admin </select></mapper>
14.在service包下創建service接口,在此包下新建impl包,創建service的實現類(別忘記打上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實現類
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 * * 服務層實現,不要忘記打上service注解 */@Servicepublic class FtbAdminServiceImpl implements FtbAdminService { //注入mapper @Autowired private FtbAdminMapper adminMapper; @Override public List<FtbAdmin> findAll() { return adminMapper.findAll(); }}
在controller包下創建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:返回整個controller返回的都是json字符串 * @RequestMapping('/admin'):請求映射 */@RestController@RequestMapping('/admin')public class FtbAdminController { //注入服務層 @Autowired private FtbAdminService adminService; //添加映射 無需與方法名一樣 @RequestMapping('/findAll') public List<FtbAdmin> findAll(){ return adminService.findAll(); }}
在spring boot啟動類添加mapper自動掃描注解
package com.example.demo;import org.mybatis.spring.annotation.MapperScan;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;//開啟mapper接口掃描,指定掃描基礎包@MapperScan(basePackages = 'com.example.demo.dao')@SpringBootApplicationpublic class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); }}
運行,在springboot啟動類的main方法上運行
18 啟動沒有報錯的話,我們可以開始測試了在瀏覽器中輸入地址↓
復制代碼 代碼如下:http://localhost:8080/admin/findAll
OK,到此為止,我們就完成了!!!
附上項目的完整結構
源碼下載
到此這篇關于快速搭建Spring Boot+MyBatis的項目IDEA(附源碼下載)的文章就介紹到這了,更多相關Spring Boot+MyBatis的項目IDEA內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章: