使用freemark根据表生成实体类

代码生成器

FreeMarker是一款模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页、电子邮件、配置文件、源代码等)的通用工具。 它不是面向最终用户的,而是一个Java类库,是一款程序员可以嵌入他们所开发产品的组件。
官方中文参考地址
在这里插入图片描述

代码生成器
代码生成器:可以生成代码的程序。
代码生成器 = 模版 + 数据 + 合成机制
代码生成器的好处:
1.节省人力成本
2.易于代码规范控制

下面是使用freemark根据数据库表名生成实体类

//所需依赖
	<dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.18</version>
    </dependency>
    <dependency>
      <groupId>org.freemarker</groupId>
      <artifactId>freemarker</artifactId>
      <version>2.3.16</version>
    </dependency>

模板文件

package com.cp;

public class ${myClass.className} {
    <#list myClass.fieldList as field>
        //${field.fieldRemarks}
        private ${field.fieldType} ${field.fieldName};
    </#list>

    <#list myClass.fieldList as field>
        public ${field.fieldType} get${field.fieldNameUpperFirstLetter}(){
            return ${field.fieldName};
        }

        public void set${field.fieldNameUpperFirstLetter}(${field.fieldType} ${field.fieldName}){
            this.${field.fieldName} = ${field.fieldName};
        }
    </#list>
}

属性类

package com.cp;
//属性名
public class Field {
	//字段名
    private String fieldName;

	//字段类型
    private String fieldType;
    
	//字段注解
    private String fieldRemarks;
	
	//字段名字母大写
    private String fieldNameUpperFirstLetter;

    public String getFieldName() {
        return fieldName;
    }

    public void setFieldName(String fieldName) {
        this.fieldName = fieldName;
    }

    public String getFieldType() {
        return fieldType;
    }

    public void setFieldType(String fieldType) {
        this.fieldType = fieldType;
    }

    public String getFieldRemarks() {
        return fieldRemarks;
    }

    public void setFieldRemarks(String fieldRemarks) {
        this.fieldRemarks = fieldRemarks;
    }

    public String getFieldNameUpperFirstLetter() {
        return fieldNameUpperFirstLetter;
    }

    public void setFieldNameUpperFirstLetter(String fieldNameUpperFirstLetter) {
        this.fieldNameUpperFirstLetter = fieldNameUpperFirstLetter;
    }
}

实体类

package com.cp;

import java.util.List;

public class MyClass {
    //生成实体类的名字
    private String className;

    //字段集合
    private List<Field> fieldList;

    public String getClassName() {
        return className;
    }

    public void setClassName(String className) {
        this.className = className;
    }

    public List<Field> getFieldList() {
        return fieldList;
    }

    public void setFieldList(List<Field> fieldList) {
        this.fieldList = fieldList;
    }
}

数据处理类

package com.cp;

import java.sql.*;
import java.util.ArrayList;
import java.util.List;

public class ClassGenerater {
    public DatabaseMetaData init(String database){
        DatabaseMetaData databaseMetaData = null;
        try {
            Class.forName("com.mysql.jdbc.Driver");
            String url = "jdbc:mysql://localhost:3306/"+database;
            Connection connection = DriverManager.getConnection(url,"root","123");
            databaseMetaData = connection.getMetaData();
        }catch (Exception e){
            e.printStackTrace();
        }

        return databaseMetaData;
    }

    //根据表名生成类
    public MyClass generateClass(String database,String tableName) throws SQLException {
        MyClass myClass = new MyClass();
        List<Field> fieldList = new ArrayList<>();
        DatabaseMetaData databaseMetaData = init(database);
        ResultSet resultSet = databaseMetaData.getColumns(null, "%", tableName, "%");
        while(resultSet.next()){
            String columnName = resultSet.getString("COLUMN_NAME");
            String columnType = resultSet.getString("TYPE_NAME");
            String columnRemarks = resultSet.getString("REMARKS");

            Field field = new Field();
            field.setFieldName(columnName);
            field.setFieldType(dbTypeToJavaType(columnType));
            field.setFieldRemarks(columnRemarks);
            field.setFieldNameUpperFirstLetter(firstLetterToUpperCase(columnName));
            fieldList.add(field);
        }
        myClass.setClassName(tableNameToClassName(tableName));
        myClass.setFieldList(fieldList);
        return myClass;
    }

    //数据库类型转java类型
    private String dbTypeToJavaType(String dbType){
        String javaType = null;
        switch (dbType){
            case "VARCHAR":
                javaType = "String";
                break;
            case "INT":
                javaType = "Integer";
                break;
            case "CHAR":
                javaType = "String";
                break;
            case "DATE":
                javaType = "Date";
                break;
            case "TIMESTAMP":
                javaType = "Date";
                break;
            case "BIGINT":
                javaType = "Long";
                break;
            case "TEXT":
                javaType = "String";
                break;
            case "DATETIME":
                javaType = "Date";
                break;
            case "DECIMAL":
                javaType = "Date";
                break;
        }
        return javaType;
    }

    //首字母变大写
    private String firstLetterToUpperCase(String src){
        return src.substring(0,1).toUpperCase()+src.substring(1);
    }

    //表名转类名 db_student_hello
    private String tableNameToClassName(String tableName){
        StringBuilder sb = new StringBuilder();
        String[] items = tableName.split("_");
        for (String item : items){
            sb.append(firstLetterToUpperCase(item));
        }
        return sb.toString();
    }
}

测试类

package com.cp;

import freemarker.template.Configuration;
import freemarker.template.Template;
import freemarker.template.TemplateException;

import java.io.*;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;

public class Test {
    public static void main(String[] args) throws IOException, SQLException, TemplateException {
        Configuration configuration = new Configuration();
        String path = Test.class.getClassLoader().getResource("").getPath();
        configuration.setDirectoryForTemplateLoading(new File(path));
        Template template = configuration.getTemplate("bean.ftl");

        //数据
        Map<String,Object> data = new HashMap<>();
        ClassGenerater classGenerater = new ClassGenerater();
        MyClass myClass = classGenerater.generateClass("库名","表名");
        data.put("myClass",myClass);

        Writer writer = new OutputStreamWriter(new FileOutputStream("输出的路径"+myClass.getClassName()+".java"));
        template.process(data,writer);
        System.out.println("finish");
    }
}

运行测试类,便会输出在指定的目录根据数据库字段名输出.java文件

Freemarker 本身并不支持生成图片,它是一个模板引擎,用于生成文本文件。但是,你可以使用 Java 的图形库(如 AWT 或 JavaFX)来生成图片,然后将图片插入到模板中。 以下是一个简单的示例,使用 AWT 绘制一张图片并将其插入到 Freemarker 模板中: Java 代码: ```java import java.awt.Color; import java.awt.Graphics2D; import java.awt.image.BufferedImage; import java.io.File; import java.io.IOException; import javax.imageio.ImageIO; public class ImageGenerator { public static void generateImage(String text, String outputFileName) throws IOException { // 创建 BufferedImage 对象 BufferedImage image = new BufferedImage(200, 100, BufferedImage.TYPE_INT_RGB); // 获取 Graphics2D 对象 Graphics2D g2d = image.createGraphics(); // 设置画布背景色为白色 g2d.setColor(Color.WHITE); g2d.fillRect(0, 0, 200, 100); // 设置字体和颜色 g2d.setColor(Color.BLACK); g2d.drawString(text, 50, 50); // 保存图片 ImageIO.write(image, "png", new File(outputFileName)); } } ``` Freemarker 模板: ```html <html> <body> <h1>欢迎使用 Freemarker</h1> <img src="${imagePath}" /> </body> </html> ``` Java 代码: ```java import freemarker.template.Configuration; import freemarker.template.Template; import java.io.File; import java.io.IOException; import java.io.StringWriter; import java.util.HashMap; import java.util.Map; public class Main { public static void main(String[] args) throws IOException { // 生成图片 ImageGenerator.generateImage("Hello, Freemarker!", "image.png"); // 创建 Freemarker 配置对象 Configuration cfg = new Configuration(Configuration.VERSION_2_3_31); cfg.setDirectoryForTemplateLoading(new File("templates")); // 加载模板文件 Template template = cfg.getTemplate("index.ftl"); // 设置模板变量 Map<String, Object> data = new HashMap<>(); data.put("imagePath", "image.png"); // 渲染模板 StringWriter out = new StringWriter(); template.process(data, out); // 输出渲染结果 System.out.println(out.toString()); } } ``` 在这个示例中,我们创建了一个名为 `ImageGenerator` 的类,其中包含一个名为 `generateImage` 的静态方法,该方法接受要绘制的文本和输出文件名作为参数。该方法使用 AWT 创建一个 `BufferedImage` 对象,并在图像上绘制文本。最后,它将图像保存为 PNG 文件。 在 `Main` 类中,我们使用 `ImageGenerator.generateImage` 方法生成一张图片,并将图片路径传递给 Freemarker 模板中的变量 `imagePath`。然后,我们加载模板文件并使用 `Template.process` 方法渲染模板,将变量 `imagePath` 替换为实际的图片路径。最后,我们将渲染结果输出到控制台。 请注意,这只是一个简单的示例,实际情况可能更为复杂。你需要根据自己的需求进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值