根据oracle数据库指定的表,使用FreeMarker生成该表对应的java实体类和sqlMap.xml

这篇博客介绍了如何利用FreeMarker模板引擎,结合Oracle数据库,自动生成指定表的Java实体类(VO.java)和SQLMap.xml文件。通过ColumnBeanVO、模板文件(bean.ftl和sqlMap.ftl)、数据库连接工具类OracleDBUtil、数据处理类DataUtils以及FreemarkerGenerator,实现了简单CRUD操作的模板生成。测试类FreemarkerGeneratorTest确保了代码的正确性。
摘要由CSDN通过智能技术生成

前言:

FreeMarker是一款模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页,电子邮件,配置文件,源代码等)的通用工具。 它不是面向最终用户的,而是一个Java类库,是一款程序员可以嵌入他们所开发产品的组件。模板编写为FreeMarker Template Language (FTL)。它是简单的,专用的语言, 不是 像PHP那样成熟的编程语言。 那就意味着要准备数据在真实编程语言中来显示,比如数据库查询和业务运算, 之后模板显示已经准备好的数据。在模板中,你可以专注于如何展现数据, 而在模板之外可以专注于要展示什么数据。

根据数据库指定的表,使用FreeMarker生成该表的VO.java类和sqlMap.xml
直接上代码:
要求:数据表字段用下划线分割单词,写清楚每个字段的注释
在这里插入图片描述

ColumnBeanVO

/**
 * ColumnBeanVO
 *
 * @author zhangsonglin
 * @version 2022/11/14 zhangsonglin
 * @description 数据库转换实体VO
 */
public class ColumnBeanVO {

    //成员变量类型
    private String type;
    //成员变量名称
    private String name;
    //注释
    private String remarks;
    //首字母大写
    private String firstUpperName;
    //字段(大写)
    private String columnName;
    //指定长度的字段大写,不足右侧补空格
    private String columnNameWithLen;

    public String getType() {
        return type;
    }

    public void setType(String type) {
        this.type = type;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getRemarks() {
        return remarks;
    }

    public void setRemarks(String remarks) {
        this.remarks = remarks;
    }

    public String getFirstUpperName() {
        return firstUpperName;
    }

    public void setFirstUpperName(String firstUpperName) {
        this.firstUpperName = firstUpperName;
    }

    public String getColumnName() {
        return columnName;
    }

    public void setColumnName(String columnName) {
        this.columnName = columnName;
    }

    public String getColumnNameWithLen() {
        return columnNameWithLen;
    }

    public void setColumnNameWithLen(String columnNameWithLen) {
        this.columnNameWithLen = columnNameWithLen;
    }

    public ColumnBeanVO(String type, String name, String remarks, String firstUpperName, String columnName, String columnNameWithLen) {
        this.type = type;
        this.name = name;
        this.remarks = remarks;
        this.firstUpperName = firstUpperName;
        this.columnName = columnName;
        this.columnNameWithLen = columnNameWithLen;
    }

    public ColumnBeanVO() {
    }

    @Override
    public String toString() {
        return "ColumnBeanVO{" +
               "type='" + type + '\'' +
               ", name='" + name + '\'' +
               ", remarks='" + remarks + '\'' +
               ", firstUpperName='" + firstUpperName + '\'' +
               ", columnName='" + columnName + '\'' +
               ", columnNameWithLen='" + columnNameWithLen + '\'' +
               '}';
    }
}

模板我们放到了:项目下的\resources\static\templates里

在这里插入图片描述
bean.ftl
实体VO.java的模板

package com.xxxx;

import com.alibaba.fastjson.JSONObject;
import java.util.Date;

public class ${className} implements Serializable {

private static final long serialVersionUID = 1L;

<#-- 循环类型及属性 -->
<#list attrs as attr>
  //${attr.remarks}
  private ${attr.type} ${attr.name};

</#list>

<#-- 循环生成set get方法 -->
<#list attrs as attr>
  public void set${attr.firstUpperName}(${attr.type} ${attr.name}) {
  this.${attr.name} = ${attr.name};
  }

  public ${attr.type} get${attr.firstUpperName}() {
  return ${attr.name};
  }

</#list>

@Override
public String toString() {
return JSONObject.toJSONString(this);
}
}

sqlMap.ftl
实现简单CRUD的sqlmap,需要复杂的也可以实现,再配置模板,传参

<?xml version="1.0&#
您可以使用FreeMarker作为模板引擎,通过编写模板来自动生成所需的实体类、指令、Controller、Service、Dao和HTML等文件。以下是一些示例模板以供参考: 实体类模板: ```java package ${basePackage}.entity; import lombok.Data; @Data public class ${className} { <#list properties as prop> /** * ${prop.comment} */ private ${prop.type} ${prop.name}; </#list> } ``` 指令模板: ```java package ${basePackage}.command; import lombok.Data; @Data public class ${className}Command { <#list properties as prop> /** * ${prop.comment} */ private ${prop.type} ${prop.name}; </#list> } ``` Controller模板: ```java package ${basePackage}.controller; import ${basePackage}.command.${className}Command; import ${basePackage}.entity.${className}; import ${basePackage}.service.${className}Service; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; @RestController @RequestMapping("/${classPath}") public class ${className}Controller { @Autowired private ${className}Service ${className?uncap_first}Service; @PostMapping public ${className} create(@RequestBody ${className}Command ${className?uncap_first}Command) { return ${className?uncap_first}Service.create(${className?uncap_first}Command); } @GetMapping("/{id}") public ${className} getById(@PathVariable Long id) { return ${className?uncap_first}Service.getById(id); } @PutMapping("/{id}") public ${className} updateById(@PathVariable Long id, @RequestBody ${className}Command ${className?uncap_first}Command) { return ${className?uncap_first}Service.updateById(id, ${className?uncap_first}Command); } @DeleteMapping("/{id}") public void deleteById(@PathVariable Long id) { ${className?uncap_first}Service.deleteById(id); } } ``` Service模板: ```java package ${basePackage}.service; import ${basePackage}.command.${className}Command; import ${basePackage}.entity.${className}; import ${basePackage}.dao.${className}Dao; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @Service public class ${className}Service { @Autowired private ${className}Dao ${className?uncap_first}Dao; public ${className} create(${className}Command ${className?uncap_first}Command) { ${className} ${className?uncap_first} = new ${className}(); BeanUtils.copyProperties(${className?uncap_first}Command, ${className?uncap_first}); return ${className?uncap_first}Dao.save(${className?uncap_first}); } public ${className} getById(Long id) { return ${className?uncap_first}Dao.getById(id); } public ${className} updateById(Long id, ${className}Command ${className?uncap_first}Command) { ${className} ${className?uncap_first} = ${className?uncap_first}Dao.getById(id); BeanUtils.copyProperties(${className?uncap_first}Command, ${className?uncap_first}); return ${className?uncap_first}Dao.save(${className?uncap_first}); } public void deleteById(Long id) { ${className?uncap_first}Dao.deleteById(id); } } ``` Dao模板: ```java package ${basePackage}.dao; import ${basePackage}.entity.${className}; import org.springframework.data.jpa.repository.JpaRepository; public interface ${className}Dao extends JpaRepository<${className}, Long> { } ``` HTML模板: ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>${className}列</title> </head> <body> <h1>${className}列</h1> <table> <thead> <tr> <th>ID</th> <#list properties as prop> <th>${prop.comment}</th> </#list> <th>操作</th> </tr> </thead> <tbody> <#list dataList as data> <tr> <td>${data.id}</td> <#list properties as prop> <td>${data[prop.name]}</td> </#list> <td> <a href="/${classPath}/${data.id}">详情</a> <a href="/${classPath}/${data.id}/edit">编辑</a> <a href="/${classPath}/${data.id}?_method=DELETE">删除</a> </td> </tr> </#list> </tbody> </table> <a href="/${classPath}/new">新建${className}</a> </body> </html> ``` 以上仅是模板的示例,您可以根据自己的需求进行修改和扩展。使用FreeMarker生成文件的具体步骤如下: 1. 定义模板文件,可以使用FreeMarker的语法编写模板; 2. 定义模板数据,可以是Java对象或者Map等; 3. 使用FreeMarker的Template类加载模板文件,得到Template对象; 4. 创建Writer对象,将渲染后的模板内容输出到文件中。 以下是一个示例代码,用于生成实体类文件: ```java import freemarker.template.Configuration; import freemarker.template.Template; import freemarker.template.TemplateException; import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.util.HashMap; import java.util.Map; public class EntityGenerator { public static void generate(String basePackage, String className, Map<String, Object> properties) throws IOException, TemplateException { Configuration cfg = new Configuration(Configuration.VERSION_2_3_28); cfg.setClassLoaderForTemplateLoading(EntityGenerator.class.getClassLoader(), "templates"); cfg.setDefaultEncoding("UTF-8"); Template template = cfg.getTemplate("entity.ftl"); Map<String, Object> data = new HashMap<>(); data.put("basePackage", basePackage); data.put("className", className); data.put("properties", properties); File file = new File(String.format("%s/src/main/java/%s/entity/%s.java", System.getProperty("user.dir"), basePackage.replaceAll("\\.", "/"), className)); FileWriter writer = new FileWriter(file); template.process(data, writer); writer.close(); System.out.println(String.format("Entity generated: %s", file.getAbsolutePath())); } } ``` 使用方式示例: ```java Map<String, Object> properties = new HashMap<>(); properties.put("id", new Property("Long", "ID")); properties.put("name", new Property("String", "名称")); properties.put("age", new Property("Integer", "年龄")); EntityGenerator.generate("com.example.demo", "User", properties); ``` 这段代码将会生成一个名为User.java实体类文件,包含id、name和age三个属性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

偷偷学习被我发现

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值