<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
分享一個小指令碼,在定義完表結構後,可以一鍵生成對應的實體類。
Database
欄中,選中對應的表,右鍵選擇對應指令碼名稱即可。整體的思路比較簡單
其中有部分註釋,如果不清楚可以留言評論,我會繼續補充解釋。有問題的話,可以共同進步。
內容如下:
import com.intellij.database.model.DasTable import com.intellij.database.util.Case import com.intellij.database.util.DasUtil import java.text.SimpleDateFormat /* * Available context bindings: * SELECTION Iterable<DasObject> * PROJECT project * FILES files helper */ packageName = "" author = "hhyy" // 型別對映,mysql中的型別,對應java中的型別 typeMapping = [ (~/bigint/) : "Long", (~/(?i)int/) : "Integer", (~/(?i)float|double|decimal|real/): "Double", (~/(?i)decimal/) : "BigDecimal", (~/(?i)datetime|timestamp|time/) : "LocalDateTime", (~/(?i)bool|boolean/) : "Boolean", (~/(?i)date/) : "LocalDate", (~/(?i)char|text/) : "String", (~/(?i)/) : "String" ] FILES.chooseDirectoryAndSave("Choose directory", "Choose where to store generated files") { dir -> SELECTION.filter { it instanceof DasTable }.each { generate(it, dir) } } def generate(table, dir) { def className = javaName(table.getName(), true) def fields = calcFields(table) packageName = getPackageName(dir) new File(dir, className + "Entity.java").withPrintWriter { out -> generate(out, table, className, fields) } } def generate(out, table, className, fields) { SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss") def nowTime = format.format(new Date()) def tableName = table.getName() out.println "package $packageName" out.println "" out.println "import lombok.Data;" out.println "" out.println "import javax.persistence.*;" out.println "import java.io.Serializable;" out.println "import java.time.LocalDateTime;" out.println "import java.math.BigDecimal;" out.println "" out.println "" out.println "/** " out.println " * @author $author" out.println " * @date $nowTime" out.println "**/" out.println "@Data" out.println "@Entity" out.println "@Table(name = "$tableName")" out.println "public class ${className}Entity implements Serializable {" out.println "" fields.each() { if (it.annos != "") out.println " ${it.annos}" // 輸出註釋 if (isNotEmpty(it.comment)) { out.println "t/** " out.println "t * $it.comment" out.println "t**/" } if (it.name == "id") { // 判斷自增 if ((tableName + "_id").equalsIgnoreCase(fields[0].colum) || "id".equalsIgnoreCase(fields[0].colum)) { out.println "t@Id" out.println "t@GeneratedValue(strategy = GenerationType.IDENTITY)" } } out.println " @Column(name = "${it.colum}", columnDefinition = "${it.sqlType}")" String colName = it.name // is_開頭的列 if (colName.startsWith("is")) { it.name = colName.substring(2).toLowerCase() } out.println "tprivate ${it.type} ${it.name};" 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() }.value // sql 欄位型別處理 String sqlTypeStr = spec; if (sqlTypeStr != null && !sqlTypeStr.isEmpty() && sqlTypeStr.contains("(")) { sqlTypeStr = sqlTypeStr.substring(0, sqlTypeStr.indexOf("(")); } fields += [[ name : javaName(col.getName(), false), colum : col.getName(), type : typeStr, sqlType: sqlTypeStr, comment: col.getComment(), annos : ""]] } } // sql列名轉java列明, 主要是一個駝峰的轉換 def javaName(str, capitalize) { def s = com.intellij.psi.codeStyle.NameUtil.splitNameIntoWords(str) .collect { Case.LOWER.apply(it).capitalize() } .join("") .replaceAll(/[^p{javaJavaIdentifierPart}[_]]/, "_") .replaceAll(/_/, "") capitalize || s.length() == 1 ? s : Case.LOWER.apply(s[0]) + s[1..-1] } /** * 獲取包名稱 * @param dir 實體類所在目錄 * @return */ static def getPackageName(dir) { String absolutePath = dir.toString() def replace = absolutePath.substring(absolutePath.indexOf("java") + 5).replace("", "."); return replace + ";" } static def isNotEmpty(content) { return content != null && content.toString().trim().length() > 0 }
在理解了groovy的語法之後(和Java相似),可以根據需要的方式,修改指令碼。比如一些公司實體類可能有固定的規範,需要新增一些東西。比如不用lombok
, 自定義get set
方法都可以,只要有了列資訊,都可以做。
將重複的工作,以指令碼的形式固化下來,將大大節省時間精力。
小到一個定時shell指令碼,再到我們編寫的程式、軟體都是在做這個工作,簡化,再簡化。
“懶惰”確實是人類進步的一大動力。
以上就是groovy指令碼定義結構表一鍵生成POJO類的詳細內容,更多關於groovy指令碼生成POJO類的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45