問:什么是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連接 &表示 & --> < 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é)果如下:
使用:
首先在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è)試一下:
測(cè)試成功!
以上這篇淺談springboot中tk.mapper代碼生成器的用法說明就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://blog.csdn.net/xqnode/article/details/88321464