之前說過怎么生成,可以參考這里當時拿出一個實體類的生成。最近有把生成的groovy
代碼改造了一番算撮,現(xiàn)在可以一鍵生成entity
、service
县昂、repository
類了肮柜。
我們現(xiàn)有的entity
、service
都是有基類可以選擇繼承的倒彰,主要看看entity
的基類BaseEntity
@Data
@MappedSuperclass
@EntityListeners({AuditingEntityListener.class})
public class BaseEntity {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id", nullable = false, length = 22, unique = true)
protected Long id;
@CreatedDate
@Column(name = "create_date", nullable = false)
protected Date createDate;
@LastModifiedDate
@Column(name = "last_modified_date")
protected Date lastModifiedDate;
@Version
@Column(name = "version", nullable = false)
protected Integer version;
}
@Data
是lombok
的注解审洞,用于自動生成get
和set
方法,使用lombok
需要在添加maven
依賴
<!-- lombok -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
再看看生成好的文件目錄結構
image.png
我們的數(shù)據(jù)表:
image.png
很好這個表是需要繼承基類生成的待讳。
打開代碼進行調整
import com.intellij.database.model.DasTable
import com.intellij.database.model.ObjectKind
import com.intellij.database.util.Case
import com.intellij.database.util.DasUtil
config = [
impSerializable : true,
extendBaseEntity : true,
extendBaseService: true
]
baseEntityPackage = "com.yija.project.framework.base.BaseEntity"
baseServicePackage = "com.yija.project.framework.base.BaseService"
baseEntityProperties = ["id", "createDate", "lastModifiedDate", "version"]
typeMapping = [
(~/(?i)bool|boolean|tinyint/) : "Boolean",
(~/(?i)bigint/) : "Long",
(~/int/) : "Integer",
(~/(?i)float|double|decimal|real/): "Double",
(~/(?i)datetime|timestamp/) : "java.util.Date",
(~/(?i)date/) : "java.sql.Date",
(~/(?i)time/) : "java.sql.Time",
(~/(?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)
}
}
//dif -> E:\DEVELOPE\Code\jpademo\src\main\java\com\demo\jpa
def generate(table, dir) {
def entityPath = "${dir.toString()}\\entity",
servicePath = "${dir.toString()}\\service",
repPath = "${dir.toString()}\\repository",
repImpPath = "${dir.toString()}\\repository\\impl"
mkdirs([entityPath, servicePath, repPath, repImpPath])
def entityName = javaName(table.getName(), true)
def fields = calcFields(table)
def basePackage = clacBasePackage(dir)
new File("${entityPath}\\${entityName}.java").withPrintWriter { out -> genEntity(out, table, entityName, fields, basePackage) }
new File("${servicePath}\\${entityName}Service.java").withPrintWriter { out -> genService(out, table, entityName, fields, basePackage) }
new File("${repPath}\\${entityName}Repository.java").withPrintWriter { out -> genRepository(out, table, entityName, fields, basePackage) }
new File("${repPath}\\${entityName}RepositoryCustom.java").withPrintWriter { out -> genRepositoryCustom(out, entityName, basePackage) }
new File("${repImpPath}\\${entityName}RepositoryImpl.java").withPrintWriter { out -> genRepositoryImpl(out, table, entityName, fields, basePackage) }
}
def genProperty(out, field) {
if (field.annos != "") out.println " ${field.annos}"
if (field.colum != field.name) {
out.println "\t@Column(name = \"${field.colum}\")"
}
out.println "\tprivate ${field.type} ${field.name};"
out.println ""
}
def genEntity(out, table, entityName, fields, basePackage) {
out.println "package ${basePackage}.entity;"
out.println ""
if (config.extendBaseEntity) {
out.println "import $baseEntityPackage;"
}
out.println "import lombok.Data;"
out.println ""
if (config.impSerializable) {
out.println "import java.io.Serializable;"
out.println ""
}
out.println "import javax.persistence.*;"
out.println ""
out.println "@Data"
out.println "@Entity"
out.println "@Table(name = \"${table.getName()}\")"
out.println "public class $entityName${config.extendBaseEntity ? " extends BaseEntity" : ""}${config.impSerializable ? " implements Serializable" : ""} {"
out.println ""
if (config.extendBaseEntity) {
// 繼承父類
fields.each() { if (!isBaseEntityProperty(it.name)) genProperty(out, it) }
} else {
// 不繼承父類
out.println "\t@Id"
fields.each() { genProperty(out, it) }
}
out.println "}"
}
def genService(out, table, entityName, fields, basePackage) {
out.println "package ${basePackage}.service;"
out.println ""
out.println "import ${basePackage}.repository.${entityName}Repository;"
if (config.extendBaseService) {
out.println "import $baseServicePackage;"
out.println "import ${basePackage}.entity.$entityName;"
}
out.println "import org.springframework.stereotype.Service;"
out.println ""
out.println "import javax.annotation.Resource;"
out.println ""
out.println "@Service"
out.println "public class ${entityName}Service${config.extendBaseService ? " extends BaseService<$entityName, ${fields[0].type}>" : ""} {"
out.println ""
out.println "\t@Resource"
out.println "\tprivate ${entityName}Repository rep;"
out.println "}"
}
def genRepository(out, table, entityName, fields, basePackage) {
out.println "package ${basePackage}.repository;"
out.println ""
out.println "import ${basePackage}.entity.$entityName;"
out.println "import org.springframework.data.jpa.repository.JpaRepository;"
out.println ""
out.println "public interface ${entityName}Repository extends JpaRepository<$entityName, ${fields[0].type}>, ${entityName}RepositoryCustom{}"
}
def genRepositoryCustom(out, entityName, basePackage) {
out.println "package ${basePackage}.repository;"
out.println ""
out.println "public interface ${entityName}RepositoryCustom { "
out.println "}"
}
def genRepositoryImpl(out, table, entityName, fields, basePackage) {
out.println "package ${basePackage}.repository.impl;"
out.println ""
out.println "import ${basePackage}.repository.${entityName}RepositoryCustom;"
out.println "import org.springframework.stereotype.Repository;"
out.println ""
out.println "import javax.persistence.EntityManager;"
out.println "import javax.persistence.PersistenceContext;"
out.println ""
out.println "@Repository"
out.println "public class ${entityName}RepositoryImpl implements ${entityName}RepositoryCustom {"
out.println ""
out.println "\t@PersistenceContext"
out.println "\tprivate EntityManager em;"
out.println "}"
}
def mkdirs(dirs) {
dirs.forEach {
def f = new File(it)
if (!f.exists()) {
f.mkdirs();
}
}
}
def clacBasePackage(dir) {
dir.toString()
.replaceAll("^.+\\\\src\\\\main\\\\java\\\\", "")
.replaceAll("\\\\", ".")
}
def isBaseEntityProperty(property) {
baseEntityProperties.find { it == property } != null
}
// 轉換類型
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
fields += [[
name : javaName(col.getName(), false),
colum: col.getName(),
type : typeStr,
annos: ""]]
}
}
def javaName(str, capitalize) {
def s = str.split(/(?<=[^\p{IsLetter}])/).collect { Case.LOWER.apply(it).capitalize() }
.join("").replaceAll(/[^\p{javaJavaIdentifierPart}]/, "_").replaceAll(/_/, "")
capitalize || s.length() == 1 ? s : Case.LOWER.apply(s[0]) + s[1..-1]
}
在config
中配置芒澜,需要使用entity
和service
的基類,實現(xiàn)Serializable
接口,然后選擇生成目錄生成
image.png
看看生成好的類吧
Entity
package com.demo.jpa.entity;
import com.yija.project.framework.base.BaseEntity;
import lombok.Data;
import java.io.Serializable;
import javax.persistence.*;
@Data
@Entity
@Table(name = "game_history")
public class GameHistory extends BaseEntity implements Serializable {
@Column(name = "user_id")
private Long userId;
private Integer score;
}
Service
package com.demo.jpa.service;
import com.demo.jpa.repository.GameHistoryRepository;
import com.yija.project.framework.base.BaseService;
import com.demo.jpa.entity.GameHistory;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
@Service
public class GameHistoryService extends BaseService<GameHistory, Long> {
@Resource
private GameHistoryRepository rep;
}
Repository
package com.demo.jpa.repository;
import com.demo.jpa.entity.GameHistory;
import org.springframework.data.jpa.repository.JpaRepository;
public interface GameHistoryRepository extends JpaRepository<GameHistory, Long>, GameHistoryRepositoryCustom{
}
RepositoryCustom
package com.demo.jpa.repository;
public interface GameHistoryRepositoryCustom {
}
RepositoryImpl
package com.demo.jpa.repository.impl;
import com.demo.jpa.repository.GameHistoryRepositoryCustom;
import org.springframework.stereotype.Repository;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
@Repository
public class GameHistoryRepositoryImpl implements GameHistoryRepositoryCustom {
@PersistenceContext
private EntityManager em;
}