当前位置: 首页 > news >正文

IDEA Groovy 脚本一键生成实体类<mybatisplus>

配置数据库(mysql)

在这里插入图片描述
在这里插入图片描述

一键生成(右键点击table)

在这里插入图片描述

配置自己的groovy脚本

在这里插入图片描述

import com.intellij.database.model.DasTable
import com.intellij.database.util.Case
import com.intellij.database.util.DasUtil
import com.intellij.database.model.ObjectKind
import java.io.*
import java.text.SimpleDateFormat
/** Available context bindings:*   SELECTION   Iterable<DasObject>*   PROJECT     project*   FILES       files helper*/
packageName = ""
typeMapping = [(~/(?i)tinyint|smallint|mediumint/)      : "Integer",(~/(?i)int/)                             : "Long",(~/(?i)bool|bit/)                        : "Boolean",(~/(?i)float|double|decimal|real/)       : "Double",(~/(?i)datetime|timestamp|date|time/)    : "Date",(~/(?i)blob|binary|bfile|clob|raw|image/): "InputStream",(~/(?i)/)                                : "String"
]FILES.chooseDirectoryAndSave("Choose directory", "Choose where to store generated files") { dir ->SELECTION.filter { it instanceof DasTable && it.getKind() == ObjectKind.TABLE }.each { generate(it, dir) }
}def generate(table, dir) {def className = javaName(table.getName(), true)def fields = calcFields(table)packageName = getPackageName(dir)PrintWriter printWriter = new PrintWriter(new OutputStreamWriter(new FileOutputStream(new File(dir, className + ".java")), "UTF-8"))printWriter.withPrintWriter {out -> generate(out, className, fields,table)}
//    new File(dir, className + ".java").withPrintWriter { out -> generate(out, className, fields,table) }
}// 获取包所在文件夹路径
def getPackageName(dir) {return dir.toString().replaceAll("\\\\", ".").replaceAll("/", ".").replaceAll("^.*src(\\.main\\.java\\.)?", "") + ";"
}def generate(out, className, fields,table) {out.println "package $packageName"out.println ""out.println "import com.baomidou.mybatisplus.annotation.IdType;"out.println "import com.baomidou.mybatisplus.annotation.TableId;"out.println "import com.baomidou.mybatisplus.annotation.TableName;"out.println "import lombok.AllArgsConstructor;"out.println "import lombok.Builder;"out.println "import lombok.Data;"out.println "import lombok.NoArgsConstructor;"out.println ""Set types = new HashSet()fields.each() {types.add(it.type)}if (types.contains("Date")) {out.println "import java.util.Date;"out.println ""}if (types.contains("InputStream")) {out.println "import java.io.InputStream;"}//  out.println "/**\n" +
//          " * @Description  \n" +
//          " * @Author  yanlp\n" +
//          " * @Date "+ new SimpleDateFormat("yyyy-MM-dd").format(new Date()) + " \n" +
//          " */"
//  out.println ""out.println "@Data"out.println "@Builder"out.println "@AllArgsConstructor"out.println "@NoArgsConstructor"out.println "@TableName(\"" + table.getName() + "\")"// out.println "public class $className  implements Serializable {"out.println "public class $className {"
//  out.println ""
//  out.println genSerialID()fields.each() {out.println ""// 输出注释if (isNotEmpty(it.comment)) {out.println "    /**"out.println "     * ${it.comment.toString()}"out.println "     */"}if (it.annos != "") out.println "${it.annos.replace("[@Id]", "")}"// 输出成员变量out.println "    private ${it.type} ${it.name};"}// 输出get/set方法
//    fields.each() {
//        out.println ""
//        out.println "\tpublic ${it.type} get${it.name.capitalize()}() {"
//        out.println "\t\treturn this.${it.name};"
//        out.println "\t}"
//        out.println ""
//
//        out.println "\tpublic void set${it.name.capitalize()}(${it.type} ${it.name}) {"
//        out.println "\t\tthis.${it.name} = ${it.name};"
//        out.println "\t}"
//    }out.println ""out.println "}"
}def calcFields(table) {DasUtil.getColumns(table).reduce([]) { fields, col ->def spec = Case.LOWER.apply(col.getDataType().getSpecification())def typeStr = typeMapping.find { p, t -> p.matcher(spec).find() }.valuedef comm =[colName : col.getName(),name :  javaName(col.getName(), false),type : typeStr,comment: col.getComment(),// annos: "\t@Column(name = \""+col.getName()+"\" )"]annos: ""]if("id".equals(Case.LOWER.apply(col.getName())))comm.annos = "    @TableId(type = IdType.AUTO)"fields += [comm]}
}// 处理类名(这里是因为我的表都是以t_命名的,所以需要处理去掉生成类名时的开头的T,
// 如果你不需要那么请查找用到了 javaClassName这个方法的地方修改为 javaName 即可)
def javaClassName(str, capitalize) {def s = com.intellij.psi.codeStyle.NameUtil.splitNameIntoWords(str).collect { Case.LOWER.apply(it).capitalize() }.join("").replaceAll(/[^\p{javaJavaIdentifierPart}[_]]/, "_")// 去除开头的T// http://developer.51cto.com/art/200906/129168.htmls = s[1..s.size() - 1]capitalize || s.length() == 1? s : Case.LOWER.apply(s[0]) + s[1..-1]
}def javaName(str, capitalize) {
//    def s = str.split(/(?<=[^\p{IsLetter}])/).collect { Case.LOWER.apply(it).capitalize() }
//            .join("").replaceAll(/[^\p{javaJavaIdentifierPart}]/, "_")
//    capitalize || s.length() == 1? s : Case.LOWER.apply(s[0]) + s[1..-1]def s = com.intellij.psi.codeStyle.NameUtil.splitNameIntoWords(str).collect { Case.LOWER.apply(it).capitalize() }.join("").replaceAll(/[^\p{javaJavaIdentifierPart}[_]]/, "_")capitalize || s.length() == 1? s : Case.LOWER.apply(s[0]) + s[1..-1]
}def isNotEmpty(content) {return content != null && content.toString().trim().length() > 0
}static String changeStyle(String str, boolean toCamel){if(!str || str.size() <= 1)return strif(toCamel){String r = str.toLowerCase().split('_').collect{cc -> Case.LOWER.apply(cc).capitalize()}.join('')return r[0].toLowerCase() + r[1..-1]}else{str = str[0].toLowerCase() + str[1..-1]return str.collect{cc -> ((char)cc).isUpperCase() ? '_' + cc.toLowerCase() : cc}.join('')}
}static String genSerialID()
{return "\tprivate static final long serialVersionUID =  "+Math.abs(new Random().nextLong())+"L;"
}

效果图

在这里插入图片描述

参考

http://www.lryc.cn/news/100871.html

相关文章:

  • 无涯教程-jQuery - Puff方法函数
  • 什么叫前后端分离?为什么需要前后端问题?解决了什么问题?
  • Vector<T> 动态数组(随机访问迭代器)(答案)
  • Istio 故障注入与重试的实验
  • Java设计模式-中介者模式
  • OpenCV实现高斯模糊加水印
  • JMeter 怎么查看 TPS 数据教程,简单易懂
  • 2023年的深度学习入门指南(19) - LLaMA 2源码解析
  • 慕课网Go-2.数组、slice、map、list
  • Django的Rest framework搭建自定义授权登录
  • 01 矩阵(力扣)多源广度优先搜索 JAVA
  • 怎么绘制简爱思维导图?用这个工具绘制很简单
  • EC200U-CN学习(三)
  • 【windows】连接共享打印机提示:0x0000011B
  • 基于“RWEQ+”集成技术在土壤风蚀模拟与风蚀模数估算、变化归因分析中的实践应用及SCI论文撰写
  • Flutter-基础Widget
  • 【数据分析专栏之Python篇】二、Jupyer Notebook安装配置及基本使用
  • ubuntu22.04 DNSSEC(加密DNS服务) configuration
  • Qt 第一讲
  • IDEA 使用 maven 搭建 spring mvc
  • Hi3536网络应用调优
  • spring拦截器 与统一格式
  • leetcode 122. 买卖股票的最佳时机 II
  • 代理模式:控制访问的设计模式
  • 2020/7/30
  • 图形编辑器开发:是否要像 Figma 一样上 wasm
  • Linux学成之路(基础篇0(二十三)MySQL服务(主从MySQL服务和读写分离——补充)
  • spring启动流程 (6完结) springmvc启动流程
  • 设计模式-中介者模式在Java中使用示例-客户信息管理
  • 14443-1-doc