溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

發(fā)布時間:2020-12-16 14:18:03 來源:億速云 閱讀:834 作者:Leah 欄目:開發(fā)技術(shù)

這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

1.IDEA 內(nèi)部新建一個項(xiàng)目,項(xiàng)目類型選擇Spring Initializr,Project SDK選擇適合你當(dāng)前環(huán)境的版本,這里我選擇的是1.8(Spring Boot 2.0以上的版本,JDK選擇請選擇1.8即以上版本),構(gòu)建服務(wù)選擇默認(rèn)就好,點(diǎn)擊Next

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

2.填寫Group和Artifact(此處我使用的是默認(rèn),請根據(jù)實(shí)際情況填寫),項(xiàng)目類型選擇Maven項(xiàng)目,語言選擇Java,打包類型選擇Jar(SpringBoot內(nèi)置Tomcat,web項(xiàng)目可以直接以Jar包的方式運(yùn)行),Java 版本選擇8,Name自己填寫,Next

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

3. 選擇Spring Boot的版本,這里先隨便選一個,我們稍后在pom文件中進(jìn)行更改,
在下面的可以選擇相應(yīng)的starter包,我們可以在此處快速選擇,也可以等到pom文件中再手動添加。我們選擇最常用的最基本的幾個:Spring bootDevTools:實(shí)現(xiàn)熱部署,Lombok:使用Lombok的注釋,Spring Web,Mybatis和MySQL驅(qū)動,選擇完畢后,Next

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

4. 選擇項(xiàng)目保存的名稱和路徑,然后Finish

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

5.等待項(xiàng)目下載完成,下面的讀條全部完成后,我們就可以點(diǎn)開項(xiàng)目查看項(xiàng)目的結(jié)構(gòu)是否完整

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

打開pom.xml文件,修改spring boot的版本為1.5.9,修改mybstis依賴的版本為1.3.1,我們使用阿里的Druid數(shù)據(jù)庫連接池,添加Druid依賴,我是用的mysql為8.0,spring boot1.5.9默認(rèn)的連接驅(qū)動是5.*的,修改驅(qū)動版本為8.0.11(在pom源碼中列出)

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

在spring boot maven plugin中添加如下配置,不配置fork無法進(jìn)行熱部署

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

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ù)庫連接池-->
  <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ū)動的名稱

# 配置數(shù)據(jù)庫連接 8.0
spring:
 datasource:
 # =====================MySQL相關(guān)配置=====================
 # 數(shù)據(jù)庫類型
 name: mysql
 #數(shù)據(jù)庫連接驅(qū)動
 driver-class-name: com.mysql.cj.jdbc.Driver
 #數(shù)據(jù)庫連接url
 url: jdbc:mysql://127.0.0.1:3306/數(shù)據(jù)庫名?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8&useSSL=false
 #數(shù)據(jù)庫連接賬號
 username: root
 #數(shù)據(jù)庫連接密碼
 password: root
 #使用druid數(shù)據(jù)源
 type: com.alibaba.druid.pool.DruidDataSource
 #==================druid相關(guān)配置=========================================
 druid:
  #監(jiān)控統(tǒng)計用的filter:stat 日志用filter:log4j 防御sql注入用filter:wall
  filters: stat,log4j,wall
  #最大鏈接數(shù)量
  max-active: 20
  #初始化時建立物理連接的個數(shù) 初始化發(fā)生在顯示調(diào)用init() 或者第一次getConnection時
  initial-size: 1
  #獲取連接時的最大等待時間 毫秒
  max-wait: 60000
  #最小連接池數(shù)量
  min-idle: 1
  time-between-eviction-runs-millis: 60000
  #鏈接保持空閑而不被驅(qū)逐的最長時間
  min-evictable-idle-time-millis: 300000
  #用來檢驗(yàn)連接是否有效的sql mysql為select 1
  # 如果validationQuery為null,testOnBorrow、testOnReturn、testWhileIdle都不會其作用
  validation-query: select 1
  # 申請連接的時候檢測,如果空閑時間大于timeBetweenEvictionRunsMillis,執(zhí)行validationQuery檢測連接是否有效
  test-while-idle: true
  # 申請連接時執(zhí)行validationQuery檢測連接是否有效,做了這個配置會降低性能
  test-on-borrow: false
  # 歸還連接時執(zhí)行validationQuery檢測連接是否有效,做了這個配置會降低性能
  test-on-return: false
  # 歸還連接時執(zhí)行validationQuery檢測連接是否有效,做了這個配置會降低性能
  pool-prepared-statements: false
  # 要啟用PSCache,必須配置大于0,當(dāng)大于0時,poolPreparedStatements自動觸發(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)

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

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)記這是一個配置類
@Configuration
public class DruidConfig {
 //配置Druid的Bean 讀取yml配置中spring.datasource為前綴的配置
 @ConfigurationProperties(prefix = "spring.datasource")
 @Bean
 public DataSource druid(){
  return new DruidDataSource();
 }
}

11.測試表結(jié)構(gòu)如下:

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

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:返回整個controller返回的都是json字符串
 * @RequestMapping("/admin"):請求映射
 */

@RestController
@RequestMapping("/admin")
public class FtbAdminController {
 
 //注入服務(wù)層
 @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接口掃描,指定掃描基礎(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啟動類的main方法上運(yùn)行

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

18 啟動沒有報錯的話,我們可以開始測試了在瀏覽器中輸入地址↓

復(fù)制代碼 代碼如下:

http://localhost:8080/admin/findAll

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

OK,到此為止,我們就完成了?。?!

附上項(xiàng)目的完整結(jié)構(gòu)

怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目

上述就是小編為大家分享的怎么在IDEA中快速搭建一個Spring Boot+MyBatis項(xiàng)目了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI