1. 程式人生 > >使用idea 搭建一個 SpringBoot + Mybatis 的maven 專案

使用idea 搭建一個 SpringBoot + Mybatis 的maven 專案

(注意專案名不能有大寫。。。。。。),把專案型別 改成 War 型別。(web專案)

使用 mybatis-generator 外掛 生成 實體類 和 介面

在 resources 目錄 中 新建一個 generatorConfig.xml 的檔案

generatorConfig.xml 檔案資訊

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE generatorConfiguration
 3         PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
4 "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> 5 6 <generatorConfiguration> 7 <context id="default" targetRuntime="MyBatis3Simple"> 8 <!--建立class時,對註釋進行控制--> 9 <commentGenerator> 10 <property name="suppressDate" value
="true" /> 11 <!--去除註釋--> 12 <property name="suppressAllComments" value="true"/> 13 </commentGenerator> 14 15 <!--jdbc的資料庫連線--> 16 <jdbcConnection driverClass="org.mariadb.jdbc.Driver" 17 connectionURL
="jdbc:mariadb://localhost:3306/test" 18 userId="oukele" password="oukele"> 19 </jdbcConnection> 20 <!-- Model模型生成器 21 targetPackage -> 指定生成的model生成所在的包名 22 targetProject -> 指定在該專案下所在的路徑 23 --> 24 <javaModelGenerator targetPackage="com.oukele.myspringbootproject.entity" targetProject="src/main/java"> 25 <!-- 是否對類CHAR型別的列的資料進行trim操作 --> 26 <property name="trimStrings" value="true" /> 27 </javaModelGenerator> 28 <!--Mapper對映檔案生成所在的目錄 為每一個數據庫的表生成對應的SqlMap檔案--> 29 <sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources"/> 30 <!-- 客戶端程式碼,生成易於使用的針對Model物件和XML配置檔案 的程式碼 31 type="ANNOTATEDMAPPER",生成Java Model 和基於註解的Mapper物件 32 type="MIXEDMAPPER",生成基於註解的Java Model 和相應的Mapper物件 33 type="XMLMAPPER",生成SQLMap XML檔案和獨立的Mapper介面 34 --> 35 <javaClientGenerator type="XMLMAPPER" targetPackage="com.oukele.myspringbootproject.dao" targetProject="src/main/java"/> 36 37 <!-- tableName 表名 % -> 全部表 --> 38 <table tableName="user"> 39 <generatedKey column="id" sqlStatement="Mysql"/> 40 </table> 41 42 </context> 43 </generatorConfiguration>
View Code

在 pom.xml 檔案新增依賴

 1             <!-- mybatis.generator 外掛  -->
 2             <plugin>
 3                 <groupId>org.mybatis.generator</groupId>
 4                 <artifactId>mybatis-generator-maven-plugin</artifactId>
 5                 <version>1.3.7</version>
 6 
 7                 <configuration>
 8                     <configurationFile>${basedir}/src/main/resources/generatorConfig.xml</configurationFile>
 9                     <overwrite>true</overwrite>
10                 </configuration>
11                 <!-- 資料庫依賴  -->
12                 <dependencies>
13                     <dependency>
14                         <groupId>org.mariadb.jdbc</groupId>
15                         <artifactId>mariadb-java-client</artifactId>
16                         <version>2.3.0</version>
17                     </dependency>
18                 </dependencies>
19             </plugin>

生成成功。

現在 來 配置 application.properties 檔案。

 1 #設定 Tomcat 埠號
 2 server.port=8081
 3 
 4 # 配置 mybatis
 5 # 設定 別名型別包 (實體類)
 6 mybatis.type-aliases-package=com.oukele.myspringbootproject.entity
 7 # 設定 mybatis 對映 的 SQL語法 xml檔案
 8 mybatis.mapper-locations=classpath:mappers/*.xml
 9 
10 # 連線資料庫
11 spring.datasource.driver-class-name=org.mariadb.jdbc.Driver
12 spring.datasource.url=jdbc:mariadb://localhost:3306/test
13 spring.datasource.username=oukele
14 spring.datasource.password=oukele
15 # 設定資料來源 (c3p0連線池)
16 spring.datasource.type=com.mchange.v2.c3p0.ComboPooledDataSource
17 
18 #啟動 熱部署
19 spring.devtools.livereload.enabled=true

如果嫌 上面的寫法 太囉嗦 可將 application.properties 檔案 字尾名改成 yml

內容改成如下:

# mybatis 配置
mybatis:
  typeAliasesPackage: com.oukele.myspringbootproject.entity
  mapperLocations: classpath:mappers/*.xml
        

spring:
  datasource:
    driver-class-name: org.mariadb.jdbc.Driver
    url: jdbc:mariadb://localhost:3306/test
    username: oukele
    password: oukele
    # 資料來源
    type: com.mchange.v2.c3p0.ComboPooledDataSource

# 這裡是預設配置
spring.devtools.restart.enabled: true
# 設定重啟的目錄
spring.devtools.restart.additional-paths: src/main/java
# classpath目錄下的WEB-INF資料夾內容修改不重啟
server:
port: 8081
 

pom.xml 檔案

  1 <?xml version="1.0" encoding="UTF-8"?>
  2 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  4     <modelVersion>4.0.0</modelVersion>
  5     <parent>
  6         <groupId>org.springframework.boot</groupId>
  7         <artifactId>spring-boot-starter-parent</artifactId>
  8         <version>2.1.1.RELEASE</version>
  9         <relativePath/> <!-- lookup parent from repository -->
 10     </parent>
 11     <groupId>com.oukele</groupId>
 12     <artifactId>my-springboot-project</artifactId>
 13     <version>0.0.1-SNAPSHOT</version>
 14     <packaging>war</packaging>
 15     <name>my-springboot-project</name>
 16     <description>Demo project for Spring Boot</description>
 17 
 18     <properties>
 19         <java.version>1.8</java.version>
 20     </properties>
 21 
 22     <dependencies>
 23         <!--監控容器-->
 24         <dependency>
 25             <groupId>org.springframework.boot</groupId>
 26             <artifactId>spring-boot-starter-actuator</artifactId>
 27         </dependency>
 28         <!-- 資源庫 -->
 29         <dependency>
 30             <groupId>org.springframework.boot</groupId>
 31             <artifactId>spring-boot-starter-data-jpa</artifactId>
 32         </dependency>
 33         <!--檢視引擎-->
 34         <dependency>
 35             <groupId>org.springframework.boot</groupId>
 36             <artifactId>spring-boot-starter-thymeleaf</artifactId>
 37         </dependency>
 38         <!-- web -->
 39         <dependency>
 40             <groupId>org.springframework.boot</groupId>
 41             <artifactId>spring-boot-starter-web</artifactId>
 42         </dependency>
 43         <!-- mybatis -->
 44         <dependency>
 45             <groupId>org.mybatis.spring.boot</groupId>
 46             <artifactId>mybatis-spring-boot-starter</artifactId>
 47             <version>1.3.2</version>
 48         </dependency>
 49         <!-- 熱部署-->
 50         <dependency>
 51             <groupId>org.springframework.boot</groupId>
 52             <artifactId>spring-boot-devtools</artifactId>
 53             <scope>runtime</scope>
 54         </dependency>
 55         <!-- Tomcat -->
 56         <dependency>
 57             <groupId>org.springframework.boot</groupId>
 58             <artifactId>spring-boot-starter-tomcat</artifactId>
 59             <scope>provided</scope>
 60         </dependency>
 61         <!-- springboot 自動配置 -->
 62         <dependency>
 63             <groupId>org.springframework.boot</groupId>
 64             <artifactId>spring-boot-starter-test</artifactId>
 65             <scope>test</scope>
 66         </dependency>
 67         <!--資料庫驅動-->
 68         <dependency>
 69             <groupId>org.mariadb.jdbc</groupId>
 70             <artifactId>mariadb-java-client</artifactId>
 71             <version>2.3.0</version>
 72         </dependency>
 73         <!--c3p0 連線池-->
 74         <dependency>
 75             <groupId>com.mchange</groupId>
 76             <artifactId>c3p0</artifactId>
 77             <version>0.9.5.2</version>
 78         </dependency>
 79     </dependencies>
 80 
 81     <build>
 82         <plugins>
 83             <plugin>
 84                 <groupId>org.springframework.boot</groupId>
 85                 <artifactId>spring-boot-maven-plugin</artifactId>
 86             </plugin>
 87 
 88             <!-- mybatis.generator 外掛  -->
 89             <plugin>
 90                 <groupId>org.mybatis.generator</groupId>
 91                 <artifactId>mybatis-generator-maven-plugin</artifactId>
 92                 <version>1.3.7</version>
 93 
 94                 <configuration>
 95                     <configurationFile>${basedir}/src/main/resources/generatorConfig.xml</configurationFile>
 96                     <overwrite>true</overwrite>
 97                 </configuration>
 98                 <!-- 資料庫依賴  -->
 99                 <dependencies>
100                     <dependency>
101                         <groupId>org.mariadb.jdbc</groupId>
102                         <artifactId>mariadb-java-client</artifactId>
103                         <version>2.3.0</version>
104                     </dependency>
105                 </dependencies>
106             </plugin>
107 
108         </plugins>
109     </build>
110 
111 </project>
View Code

這裡,我們啟動專案,看下能不能啟動。

首先在 templates 檔案中 新建一個 index.html 網頁

然後

 

最後,

啟動成功

效果如下: