使用idea 搭建一個 SpringBoot + Mybatis 的maven 專案
阿新 • • 發佈:2019-01-06
(注意專案名不能有大寫。。。。。。),把專案型別 改成 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"View Code4 "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>
在 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 網頁
然後
最後,
啟動成功
效果如下: