激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - Java教程 - 淺談springboot中tk.mapper代碼生成器的用法說明

淺談springboot中tk.mapper代碼生成器的用法說明

2020-09-30 00:33xqnode Java教程

這篇文章主要介紹了淺談springboot中tk.mapper代碼生成器的用法說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

問:什么是tk.mapper?

答:這是一個(gè)通用的mapper框架,相當(dāng)于把mybatis的常用數(shù)據(jù)庫(kù)操作方法封裝了一下,它實(shí)現(xiàn)了jpa的規(guī)范,簡(jiǎn)單的查詢更新和插入操作都可以直接使用其自帶的方法,無需寫額外的代碼。

而且它還有根據(jù)實(shí)體的不為空的字段插入和更新的方法,這個(gè)是非常好用的哈。

而且它的集成非常簡(jiǎn)單和方便,下面我來演示下使用它怎么自動(dòng)生成代碼。

pom中引入依賴,這里引入tk.mybatis.mapper的版本依賴是因?yàn)樵趍apper-spring-boot-starter的新版本中沒有MapperPlugin這個(gè)類,無法提供代碼生成的功能,在老版本中有:

?
1
2
3
4
5
6
7
8
9
10
11
12
<!--通用mapper-->
<dependency>
 <groupId>tk.mybatis</groupId>
 <artifactId>mapper-spring-boot-starter</artifactId>
 <version>2.1.5</version>
</dependency>
<!--代碼生成使用-->
<dependency>
 <groupId>tk.mybatis</groupId>
 <artifactId>mapper</artifactId>
 <version>3.4.2</version>
</dependency>

配置generatorConfig.xml:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
  PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
  "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<!-- 配置生成器 -->
<generatorConfiguration>
 <!--執(zhí)行g(shù)enerator插件生成文件的命令: call mvn mybatis-generator:generate -e -->
 <!-- 引入配置文件 -->
 <properties resource="generator.properties"/>
 <!--classPathEntry:數(shù)據(jù)庫(kù)的JDBC驅(qū)動(dòng),換成你自己的驅(qū)動(dòng)位置 可選 -->
 <classPathEntry
   location="D:\iflytek\maven\repository\mysql\mysql-connector-java\8.0.15\mysql-connector-java-8.0.15.jar"/>
 
 <!-- 一個(gè)數(shù)據(jù)庫(kù)一個(gè)context -->
 <!--defaultModelType="flat" 大數(shù)據(jù)字段,不分表 -->
 <context id="MysqlTables" targetRuntime="MyBatis3Simple" defaultModelType="flat">
  <!-- 自動(dòng)識(shí)別數(shù)據(jù)庫(kù)關(guān)鍵字,默認(rèn)false,如果設(shè)置為true,根據(jù)SqlReservedWords中定義的關(guān)鍵字列表;
  一般保留默認(rèn)值,遇到數(shù)據(jù)庫(kù)關(guān)鍵字(Java關(guān)鍵字),使用columnOverride覆蓋 -->
  <property name="autoDelimitKeywords" value="true"/>
  <!-- 生成的Java文件的編碼 -->
  <property name="javaFileEncoding" value="utf-8"/>
  <!-- beginningDelimiter和endingDelimiter:指明數(shù)據(jù)庫(kù)的用于標(biāo)記數(shù)據(jù)庫(kù)對(duì)象名的符號(hào),比如ORACLE就是雙引號(hào),MYSQL默認(rèn)是`反引號(hào); -->
  <property name="beginningDelimiter" value="`"/>
  <property name="endingDelimiter" value="`"/>
 
  <!-- 格式化java代碼 -->
  <property name="javaFormatter" value="org.mybatis.generator.api.dom.DefaultJavaFormatter"/>
  <!-- 格式化XML代碼 -->
  <property name="xmlFormatter" value="org.mybatis.generator.api.dom.DefaultXmlFormatter"/>
  <plugin type="org.mybatis.generator.plugins.SerializablePlugin"/>
  <!--覆蓋xml文件-->
  <plugin type="com.xqnode.boot.util.OverwriteXmlPlugin"/>
  <!--toString-->
  <!--<plugin type="org.mybatis.generator.plugins.ToStringPlugin"/>-->
  <plugin type="tk.mybatis.mapper.generator.MapperPlugin">
   <property name="mappers" value="tk.mybatis.mapper.common.Mapper"/>
  </plugin>
 
  <!-- 注釋 type="com.xqnode.boot.util.CommentGenerator" -->
  <commentGenerator>
   <property name="suppressAllComments" value="true"/><!-- 是否取消注釋 -->
   <property name="suppressDate" value="true"/> <!-- 是否生成注釋代時(shí)間戳-->
  </commentGenerator>
 
  <!-- jdbc連接 &amp;表示 & -->
  <jdbcConnection driverClass="${jdbc.driverClass}"
      connectionURL="${jdbc.connectionURL}"
      userId="${jdbc.userId}"
      password="${jdbc.password}"/>
  <!-- 類型轉(zhuǎn)換 -->
  <javaTypeResolver>
   <!-- 是否使用bigDecimal, false可自動(dòng)轉(zhuǎn)化以下類型(Long, Integer, Short, etc.) -->
   <property name="forceBigDecimals" value="false"/>
  </javaTypeResolver>
 
  <!-- 生成實(shí)體類地址 -->
  <javaModelGenerator targetPackage="com.xqnode.boot.model" targetProject="src/main/java">
   <property name="enableSubPackages" value="false"/>
   <property name="trimStrings" value="true"/>
  </javaModelGenerator>
  <!-- 生成mapxml文件 -->
  <sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources">
   <property name="enableSubPackages" value="false"/>
  </sqlMapGenerator>
  <!-- 生成mapxml對(duì)應(yīng)client,也就是接口dao -->
  <javaClientGenerator targetPackage="com.xqnode.boot.dao" targetProject="src/main/java"
        type="XMLMAPPER">
   <property name="enableSubPackages" value="false"/>
  </javaClientGenerator>
  <!-- table可以有多個(gè),每個(gè)數(shù)據(jù)庫(kù)中的表都可以寫一個(gè)table,tableName表示要匹配的數(shù)據(jù)庫(kù)表,也可以在tableName屬性中通過使用%通配符來匹配所有數(shù)據(jù)庫(kù)表,只有匹配的表才會(huì)自動(dòng)生成文件 -->
  <!-- tableName=% 則匹配數(shù)據(jù)庫(kù)的所有表,注意將domainObjectName和mapperName置為空-->
  <!-- enableCountByExample等設(shè)置生成簡(jiǎn)單的crud操作方法-->
  <table tableName="${table.name}" domainObjectName="${domain.object.name}" mapperName="${mapper.name}">
   <property name="useActualColumnNames" value="false"/>
   <!-- 數(shù)據(jù)庫(kù)表主鍵 -->
   <generatedKey column="id" sqlStatement="Mysql" identity="true"/>
  </table>
 </context>
</generatorConfiguration>

 

基礎(chǔ)配置 generator.properties:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
#jdbc
jdbc.driverClass=com.mysql.cj.jdbc.Driver
jdbc.connectionURL=jdbc:mysql://localhost:3306/test?serverTimezone=UTC&nullCatalogMeansCurrent=true
jdbc.userId=root
jdbc.password=123456
 
#project
project.name=springboot-mybatis
 
#table
table.name=t_user
domain.object.name=User
mapper.name=UserMapper

使用代碼的方式生成,工具GeneratorUtil:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
package com.xqnode.boot.util;
import org.mybatis.generator.api.MyBatisGenerator;
import org.mybatis.generator.config.Configuration;
import org.mybatis.generator.config.xml.ConfigurationParser;
import org.mybatis.generator.internal.DefaultShellCallback;
 
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
 
/**
 * 代碼生成工具 具體的配置在generator.properties中
 * create by qingxia4 on 2019/3/7 10:56
 */
public class GeneratorUtil {
 public static void main(String[] args) throws Exception {
  //MBG 執(zhí)行過程中的警告信息
  List<String> warnings = new ArrayList<>();
  //當(dāng)生成的代碼重復(fù)時(shí),覆蓋原代碼
  boolean overwrite = true;
  //讀取我們的 MBG 配置文件
  InputStream is = GeneratorUtil.class.getResourceAsStream("/generatorConfig.xml");
  ConfigurationParser cp = new ConfigurationParser(warnings);
  Configuration config = cp.parseConfiguration(is);
  is.close();
 
  DefaultShellCallback callback = new DefaultShellCallback(overwrite);
  //創(chuàng)建 MBG
  MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
  //執(zhí)行生成代碼
  myBatisGenerator.generate(null);
  //輸出警告信息
  for (String warning : warnings) {
   System.err.println(warning);
  }
  System.out.println("-----success-----");
 }
}

這里還使用了一個(gè)覆蓋xml的插件OverwriteXmlPlugin,使用這個(gè)插件每次新生成的xml文件會(huì)完全覆蓋老的xml文件,這個(gè)插件已經(jīng)在上面的generatorConfig.xml中配置過了

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
package com.xqnode.boot.util;
 
import java.util.List;
import org.mybatis.generator.api.GeneratedXmlFile;
import org.mybatis.generator.api.IntrospectedTable;
import org.mybatis.generator.api.PluginAdapter;
 
/**
 * @version 1.0.0
 */
public class OverwriteXmlPlugin extends PluginAdapter {
 
 @Override
 public boolean validate(List<String> warnings) {
  return true;
 }
 
 @Override
 public boolean sqlMapGenerated(GeneratedXmlFile sqlMap, IntrospectedTable introspectedTable) {
  sqlMap.setMergeable(false);
  return super.sqlMapGenerated(sqlMap, introspectedTable);
 }
}

最后,運(yùn)行GeneratorUtil 的main方法,就可以生成dao、model和mapper.xml文件了。而且生成的代碼非常簡(jiǎn)潔,這是因?yàn)閠k.mapper代碼生成的插件中已經(jīng)做了相應(yīng)的處理。生成的結(jié)果如下:

淺談springboot中tk.mapper代碼生成器的用法說明

使用:

首先在application.yml中配置xml和數(shù)據(jù)模型的位置:

?
1
2
3
mybatis:
 mapper-locations: classpath:mapper/*.xml
 type-aliases-package: com.xqnode.boot.model

然后在啟動(dòng)類上加上注解@MapperScan(“com.xqnode.boot.dao”)掃描dao的位置,注意這個(gè)注解式來自tk.mybatis.spring.annotation包下的,千萬(wàn)別引用錯(cuò)了。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
package com.xqnode.boot;
 
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import tk.mybatis.spring.annotation.MapperScan;
 
@SpringBootApplication
@MapperScan("com.xqnode.boot.dao")
public class Application {
 
 public static void main(String[] args) {
  SpringApplication.run(Application.class, args);
 }
 
}

現(xiàn)在就可以編寫controller測(cè)試了:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
package com.xqnode.boot.controller;
import cn.hutool.crypto.SecureUtil;
import com.xqnode.boot.dao.UserMapper;
import com.xqnode.boot.model.User;
import org.springframework.web.bind.annotation.*;
import tk.mybatis.mapper.entity.Example;
 
import javax.annotation.Resource;
import java.util.Date;
import java.util.List;
 
/**
 * created by xiaqing on 2019/3/6 20:11
 */
@RestController
@RequestMapping("/user")
public class UserController {
 
 @Resource
 private UserMapper userMapper;
 
 /**
  * 查詢所有用戶
  * @return
  */
 @GetMapping("/all")
 public List<User> findAll() {
  return userMapper.selectAll();
 }
 
 /**
  * 注冊(cè)新用戶
  * @param user
  * @return
  */
 @PostMapping("/registry")
 public Integer registry(@RequestBody User user) {
  String pwdMd5 = SecureUtil.md5(user.getPassword());
  user.setPassword(pwdMd5);
  user.setCreateTime(new Date());
  return userMapper.insertSelective(user);
 }
 
 /**
  * 根據(jù)登錄名修改密碼
  * @param user
  * @return
  */
 @PutMapping("/changePwd")
 public Integer changePwd(@RequestBody User user) {
  String pwdMd5 = SecureUtil.md5(user.getPassword());
  user.setPassword(pwdMd5);
  Example example = new Example(User.class);
  example.createCriteria().andEqualTo("loginName", user.getLoginName());
  return userMapper.updateByExampleSelective(user, example);
 }
}

接口訪問測(cè)試一下:

淺談springboot中tk.mapper代碼生成器的用法說明

測(cè)試成功!

以上這篇淺談springboot中tk.mapper代碼生成器的用法說明就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://blog.csdn.net/xqnode/article/details/88321464

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品一区二区中文字幕 | 国外成人在线视频网站 | 黄色小视频免费在线观看 | 韩国草草影院 | h视频免费看 | 日本免费成人网 | 视频毛片 | 日本不卡一区二区三区在线 | 日本综合久久 | 久久久av亚洲男天堂 | 韩国十九禁高潮床戏在线观看 | 亚洲第一成人久久网站 | 日韩精品久久久久久久电影99爱 | 久久免费综合视频 | 伊人成人免费视频 | 亚洲5区 | 欧美日韩国产成人在线 | 精品成人免费一区二区在线播放 | 看国产精品 | 懂色av懂色aⅴ精彩av | 亚洲午夜精品视频 | 欧美精品一区二区三区在线播放 | 亚洲国产在 | 毛片免费试看 | 国产精品一区二区x88av | 午夜视频在线观看免费视频 | 久久综合九色综合久久久精品综合 | 亚洲成人免费视频在线 | 成人免费一区二区三区 | 一区二区三区四区在线 | 91久久国产综合久久91精品网站 | 一区二区三视频 | 91看片免费版| 成人国产高清 | 日本久久精品视频 | 国产 视频 一区二区 | 中文字幕在线不卡视频 | 久久亚洲第一 | 91短视频在线观看视频 | 一级电影中文字幕 | 欧美性色生活片免费播放 |