国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:39日期:2023-04-19 17:16:09

問(wèn):什么是tk.mapper?

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

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

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

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

<!--通用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:

<?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:iflytekmavenrepositorymysqlmysql-connector-java8.0.15mysql-connector-java-8.0.15.jar'/> <!-- 一個(gè)數(shù)據(jù)庫(kù)一個(gè)context --> <!--defaultModelType='flat' 大數(shù)據(jù)字段,不分表 --> <context 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屬性中通過(guò)使用%通配符來(lái)匹配所有數(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:

#jdbcjdbc.driverClass=com.mysql.cj.jdbc.Driverjdbc.connectionURL=jdbc:mysql://localhost:3306/test?serverTimezone=UTC&nullCatalogMeansCurrent=truejdbc.userId=rootjdbc.password=123456#projectproject.name=springboot-mybatis#tabletable.name=t_userdomain.object.name=Usermapper.name=UserMapper

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

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í)行過(guò)程中的警告信息 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中配置過(guò)了

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代碼生成器的用法說(shuō)明

使用:

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

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

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

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è)試了:

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); }}

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

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

測(cè)試成功!

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

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 久久国产精品免费一区二区三区 | 国产成人免费在线观看 | 精品久久一区 | 99精品国产一区二区三区 | 成人性版蝴蝶影院污 | 成人性版蝴蝶影院污 | 97精品国产福利一区二区三区 | 国产又粗又黄又湿又大 | 欧美精品亚洲人成在线观看 | 亚洲精品国自产拍影院 | 久久久久久青草大香综合精品 | 成人黄色毛片 | 成人在免费视频手机观看网站 | 日韩在线精品视频 | 可以免费看黄的网站 | 国内外成人免费视频 | 亚洲精品久久久久影 | 亚洲精品国产精品精 | 国产精品色内内在线播放 | 九色porny真实丨国产18 | 手机看片福利视频 | 欧美黑寡妇特a级做爰 | 亚洲视频网站在线观看 | 国产精品欧美一区二区三区 | 中文字幕视频网站 | 久久久久久久久久综合情日本 | 日韩高清在线二区 | 美女视频免费黄 | 黄www| 亚洲人成在线播放网站 | 国产在线精品一区二区高清不卡 | 国产精品久久久久网站 | 在线成人97观看 | 亚洲在线日韩 | 最新国产精品自拍 | a理论片| 日韩一级欧美一级 | 亚洲精品视频区 | a级国产乱理伦片在线观看99 | 青青草国产免费一区二区 | 国产一级毛片国产 |