使用idea 搭建一個 SpringBoot + Mybatis + logback 的maven 項

(注意項目名不能有大寫。。。。。。),把項目類型 改爲 War 類型。(web項目)html

使用 mybatis-generator 插件 生成 實體類 和 接口

在 resources 目錄 中 新建一個 generatorConfig.xml 的文件java

generatorConfig.xml 文件信息web

複製代碼
 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>
複製代碼

在 pom.xml 文件添加依賴spring

複製代碼
 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>
複製代碼

生成成功。sql

如今 來 配置 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:mapper/*.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數據庫

內容改爲以下:springboot

複製代碼
# mybatis 配置
mybatis:
  typeAliasesPackage: com.oukele.myspringbootproject.entity
  mapperLocations: classpath:mapper/*.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 文件

  View Code

這裏,咱們啓動項目,看下能不能啓動。mybatis

首先在 templates 文件中 新建一個 index.html 網頁app

而後maven

 

最後,

啓動成功

效果以下:

開始咱們的主菜。

項目結構

service包中UserService接口

複製代碼
1 package com.oukele.myspringbootproject.service;
2 
3 import com.oukele.myspringbootproject.entity.User;
4 import java.util.List;
5 
6 
7 public interface UserService {
8     List<User> listAll();
9 }
複製代碼

serviceImp包中UserServiceImp類

複製代碼
 1 package com.oukele.myspringbootproject.serviceImp;
 2 
 3 import com.oukele.myspringbootproject.dao.UserMapper;
 4 import com.oukele.myspringbootproject.entity.User;
 5 import com.oukele.myspringbootproject.service.UserService;
 6 import org.springframework.beans.factory.annotation.Autowired;
 7 import org.springframework.stereotype.Service;
 8 
 9 import java.util.List;
10 
11 @Service
12 public class UserServiceImp implements UserService {
13 
14     @Autowired
15     private UserMapper userMapper;//這裏出現紅色波浪線,並不影響使用
16 
17     @Override
18     public List<User> listAll() {
19         return userMapper.selectAll();
20     }
21 }
複製代碼

controller包中Usercontroller類

複製代碼
package com.oukele.myspringbootproject.controller;

import com.oukele.myspringbootproject.entity.User;
import com.oukele.myspringbootproject.serviceImp.UserServiceImp;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController
public class UserController {

    @Autowired
    private UserServiceImp userServiceImp;

    @GetMapping(path = "/list")
    public List<User> getAll(){
        return userServiceImp.listAll();
    }
}
複製代碼

 

類的修改。。。

複製代碼
package com.oukele.myspringbootproject;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
@MapperScan("com.oukele.myspringbootproject.dao")//掃描接口
public class MySpringbootProjectApplication {

    public static void main(String[] args) {
        SpringApplication.run(MySpringbootProjectApplication.class, args);
    }

}
複製代碼

重啓項目,訪問/list 的結果:

使用logback日誌:

在resources文件中 新建logback-spring.xml 文件 (springboot默認集成了 logback 直接在resources建立 logback-spring.xml便可)

複製代碼
 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <configuration>
 3     <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
 4         <layout class="ch.qos.logback.classic.PatternLayout">
 5             <Pattern>
 6                 %msg%n
 7             </Pattern>
 8         </layout>
 9     </appender>
10 
11     <logger name="com.oukele.myspringbootproject.dao" level="TRACE" />
12 
13     <root level="error">
14         <appender-ref ref="STDOUT" />
15     </root>
16 </configuration>
複製代碼

 

從新啓動(結果):

相關文章
相關標籤/搜索