(注意項目名不能有大寫。。。。。。),把項目類型 改爲 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 文件

這裏,咱們啓動項目,看下能不能啓動。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>
從新啓動(結果):