日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

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

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

問:什么是tk.mapper?

答:這是一個通用的mapper框架,相當于把mybatis的常用數據庫操作方法封裝了一下,它實現了jpa的規范,簡單的查詢更新和插入操作都可以直接使用其自帶的方法,無需寫額外的代碼。

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

而且它的集成非常簡單和方便,下面我來演示下使用它怎么自動生成代碼。

pom中引入依賴,這里引入tk.mybatis.mapper的版本依賴是因為在mapper-spring-boot-starter的新版本中沒有MapperPlugin這個類,無法提供代碼生成的功能,在老版本中有:

<!--通用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> <!--執行generator插件生成文件的命令: call mvn mybatis-generator:generate -e --> <!-- 引入配置文件 --> <properties resource='generator.properties'/> <!--classPathEntry:數據庫的JDBC驅動,換成你自己的驅動位置 可選 --> <classPathEntry location='D:iflytekmavenrepositorymysqlmysql-connector-java8.0.15mysql-connector-java-8.0.15.jar'/> <!-- 一個數據庫一個context --> <!--defaultModelType='flat' 大數據字段,不分表 --> <context targetRuntime='MyBatis3Simple' defaultModelType='flat'> <!-- 自動識別數據庫關鍵字,默認false,如果設置為true,根據SqlReservedWords中定義的關鍵字列表; 一般保留默認值,遇到數據庫關鍵字(Java關鍵字),使用columnOverride覆蓋 --> <property name='autoDelimitKeywords' value='true'/> <!-- 生成的Java文件的編碼 --> <property name='javaFileEncoding' value='utf-8'/> <!-- beginningDelimiter和endingDelimiter:指明數據庫的用于標記數據庫對象名的符號,比如ORACLE就是雙引號,MYSQL默認是`反引號; --> <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'/> <!-- 是否生成注釋代時間戳--> </commentGenerator> <!-- jdbc連接 &amp;表示 & --> <jdbcConnection driverClass='${jdbc.driverClass}' connectionURL='${jdbc.connectionURL}' userId='${jdbc.userId}' password='${jdbc.password}'/> <!-- 類型轉換 --> <javaTypeResolver> <!-- 是否使用bigDecimal, false可自動轉化以下類型(Long, Integer, Short, etc.) --> <property name='forceBigDecimals' value='false'/> </javaTypeResolver> <!-- 生成實體類地址 --> <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對應client,也就是接口dao --> <javaClientGenerator targetPackage='com.xqnode.boot.dao' targetProject='src/main/java'type='XMLMAPPER'> <property name='enableSubPackages' value='false'/> </javaClientGenerator> <!-- table可以有多個,每個數據庫中的表都可以寫一個table,tableName表示要匹配的數據庫表,也可以在tableName屬性中通過使用%通配符來匹配所有數據庫表,只有匹配的表才會自動生成文件 --> <!-- tableName=% 則匹配數據庫的所有表,注意將domainObjectName和mapperName置為空--> <!-- enableCountByExample等設置生成簡單的crud操作方法--> <table tableName='${table.name}' domainObjectName='${domain.object.name}' mapperName='${mapper.name}'> <property name='useActualColumnNames' value='false'/> <!-- 數據庫表主鍵 --> <generatedKey column='id' sqlStatement='Mysql' identity='true'/> </table> </context></generatorConfiguration>

基礎配置 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 執行過程中的警告信息 List<String> warnings = new ArrayList<>(); //當生成的代碼重復時,覆蓋原代碼 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); //創建 MBG MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings); //執行生成代碼 myBatisGenerator.generate(null); //輸出警告信息 for (String warning : warnings) { System.err.println(warning); } System.out.println('-----success-----'); }}

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

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

最后,運行GeneratorUtil 的main方法,就可以生成dao、model和mapper.xml文件了。而且生成的代碼非常簡潔,這是因為tk.mapper代碼生成的插件中已經做了相應的處理。生成的結果如下:

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

使用:

首先在application.yml中配置xml和數據模型的位置:

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

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

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

現在就可以編寫controller測試了:

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(); } /** * 注冊新用戶 * @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); } /** * 根據登錄名修改密碼 * @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); }}

接口訪問測試一下:

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

測試成功!

以上這篇淺談springboot中tk.mapper代碼生成器的用法說明就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
制服诱惑一区二区| 国产日本久久| 国产一区二区三区四区大秀| 青草久久视频| 欧美日韩亚洲国产精品| 成人国产精品| 久久国产高清| 免费看的黄色欧美网站| 男人的天堂久久精品| 亚洲天堂免费| 亚洲另类黄色| 国产精品www994| 97精品在线| 美女毛片一区二区三区四区| 久久不射中文字幕| 国产日产精品_国产精品毛片| 精品久久久网| 欧美不卡在线| 国产亚洲欧美日韩精品一区二区三区| аⅴ资源天堂资源库在线| 国产在线日韩精品| 欧美一级精品| 日本在线不卡视频一二三区| 国产精品xxxav免费视频| 色一区二区三区四区| 91看片一区| 丝袜脚交一区二区| 国产精品日本一区二区三区在线| 国产一区三区在线播放| 欧美特黄一级大片| 婷婷综合福利| 最新中文字幕在线播放| 噜噜噜躁狠狠躁狠狠精品视频| 日韩精品视频中文字幕| 精品国产一区二区三区噜噜噜| 99精品在线| 一区免费视频| 神马午夜久久| 国产精品普通话对白| 国产日韩欧美三区| 快播电影网址老女人久久| 日韩在线卡一卡二| sm捆绑调教国产免费网站在线观看| 欧美91视频| 国产精品一区二区三区美女 | 亚洲精品综合| 精品久久久中文字幕| 亚洲精品第一| 亚洲第一精品影视| 精品视频高潮| 日韩精品高清不卡| 亚洲国内欧美| 国产一区二区亚洲| 亚洲精品高潮| 欧美日韩少妇| 美女视频黄久久| 蜜臀av一区二区三区| 天堂√8在线中文| 久久激情综合网| 性一交一乱一区二区洋洋av| 日韩欧美不卡| 国产精品亚洲产品| 亚洲精品动态| 亚洲免费网址| 久久蜜桃av| 成人在线黄色| 国产精品视频一区二区三区 | 国产日韩欧美一区在线| 亚洲免费影院| 91精品一区二区三区综合| 麻豆国产欧美日韩综合精品二区| 综合激情五月婷婷| 天堂成人免费av电影一区 | 国产精品福利在线观看播放| 日韩黄色在线观看| 在线国产日韩| 蜜臀久久久久久久| 国产精品人人爽人人做我的可爱| 亚洲天堂av影院| 精品三级国产| 久久久精品区| 国内揄拍国内精品久久| 国产精品欧美大片| 69堂免费精品视频在线播放| 视频精品一区| 综合一区二区三区| 男人操女人的视频在线观看欧美| 99在线精品免费视频九九视| 久久久国产亚洲精品| 日韩电影二区| 日韩精品一区二区三区免费观看| 国产精品国产三级国产在线观看| 美女视频黄免费的久久| 国产乱码精品| 亚洲不卡系列| 久久一区二区三区电影| 精品久久影院| 国产成人精品一区二区三区视频 | 毛片在线网站| 成人日韩在线观看| 久久久人人人| 欧美丰满日韩| 激情视频网站在线播放色| xxxxx性欧美特大| 国产在线|日韩| 欧美亚洲精品在线| 亚洲制服少妇| 亚洲97av| 国产美女视频一区二区| 国产精品久久久久9999高清| 日本不卡的三区四区五区| 午夜性色一区二区三区免费视频| 日韩精品中文字幕一区二区| 日韩精品导航| 国产精品一区二区三区www| 久久中文字幕一区二区三区| 国语精品一区| 久久精品一区二区不卡| 国产亚洲精品v| 日韩美女国产精品| 欧美国产免费| 亚洲va中文在线播放免费| 亚洲国产一区二区在线观看| 美国欧美日韩国产在线播放| 奇米亚洲欧美| 国产精品久久久久久久久久10秀 | 久久女人天堂| 久久天堂成人| 蜜桃视频一区二区| 国产女人18毛片水真多18精品| 久久97视频| 婷婷亚洲五月| 国产日产精品_国产精品毛片| 国产白浆在线免费观看| 亚洲综合另类| 精品一区二区三区亚洲| 久久婷婷久久| 天堂av一区| 欧美午夜精彩| 欧美精品自拍| 日韩中出av| 9999国产精品| 久久影视一区| 人人爱人人干婷婷丁香亚洲| 国产三级一区| 国产99精品| 国产欧美一级| 不卡视频在线| 久久精品伊人| 亚洲伊人精品酒店| 精品美女在线视频| 在线亚洲一区| 久久精品国产99国产精品| 亚洲精品欧美| 五月婷婷六月综合| 日本在线一区二区三区| 中文字幕在线高清| 中文字幕日韩亚洲| 亚洲成av在线| 丝袜a∨在线一区二区三区不卡| 欧美国产极品| 亚洲精品一区二区在线播放∴| 日本精品黄色| 亚洲精品美女91| 久久免费黄色| 国产福利一区二区三区在线播放| 免费精品国产| 久久99国产精品视频| 亚洲色图网站| 99久久99视频只有精品| 国产精品国码视频| 六月婷婷一区| 亚洲午夜一级| 欧美激情91| 老司机精品久久| 午夜av成人| 亚洲精品在线观看91| 欧美中文日韩| 国产欧美一区二区三区精品酒店 | 国产一区2区| 7777精品| 天堂俺去俺来也www久久婷婷| 美女少妇全过程你懂的久久| 国产精品成人a在线观看| 国产精品日本一区二区不卡视频 | 中文一区一区三区免费在线观| 蜜桃av.网站在线观看| 国产精品videosex极品| 丝袜脚交一区二区| 99热免费精品| 国产一区二区中文| 五月天av在线| 国内揄拍国内精品久久| 欧美一区成人| 香蕉久久久久久| 亚洲aa在线| 亚洲精品影视| 首页亚洲欧美制服丝腿| 激情久久久久久| 久久理论电影|