如何自定义代码生成器(下)

4.2 编码

4.2.1 常量类
package freemarker.constant;

public class TemplateConstant {
   

    //实体类模板
    public static final String entityTemplate = "templates/Entity.ftl";
    //Mapper模板
    public static final String mapperTemplate = "templates/Mapper.ftl";
    //Mapper映射文件模版
    public static final String mapperXmlTemplate = "templates/MapperXml.ftl";
    //service模版
    public static final String serviceTemplate = "templates/Service.ftl";
    //service实现类模版
    public static final String serviceImplTemplate = "templates/ServiceImpl.ftl";
    //controller模版
    public static final String controllerTemplate = "templates/Controller.ftl";
    //vo模版
    public static final String entityVoTemplate = "templates/EntityVo.ftl";
    //dto模版
    public static final String entityDtoTemplate = "templates/EntityDto.ftl";
    //pom模版
    public static final String pomTemplate = "templates/pom.ftl";
    //application.yml模版
    public static final String applicationTemplate = "templates/application.ftl";
}
4.2.2 工具类

(1)DbUtil数据库工具类

package freemarker.util;

import freemarker.param.ColumnClass;
import freemarker.param.TableClass;
import lombok.Getter;
import lombok.Setter;

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

/**
 * 数据库工具类
 */
@Setter
@Getter
public class DbUtil {
   

    //数据库连接地址
    private String url = "jdbc:mysql://localhost:3306/heima_leadnews_wemedia?useSSL=false&nullCatalogMeansCurrent=true&serverTimezone=UTC";
    //数据库用户名
    private String username = "root";
    //数据库密码

    private String password = "123456";
    //数据库驱动
    private String driver = "com.mysql.jdbc.Driver";

    //数据库名称
    private String dbName = null;

    private Connection connection =null;

    /**
     * 获取jdbc链接
     * @return
     * @throws Exception
     */
    public Connection getConnection() throws Exception{
   
        Properties pro = new Properties();
        pro.setProperty("user", username);
        pro.setProperty("password", password);
        pro.put("useInformationSchema", "true");//获取mysql表注释
        //pro.setProperty("remarksReporting","true");//获取oracle表注释
        Class.forName(driver);
        connection = DriverManager.getConnection(url, pro);
        return connection;
    }

    /**
     * 获取当前数据库下的所有表名称及注释
     * @return
     * @throws Exception
     */
    public List<TableClass> getAllTables() throws Exception {
   
        List<TableClass> list = new ArrayList<>();
        //获取链接
        Connection conn = getConnection();
        //获取元数据
        DatabaseMetaData metaData = conn.getMetaData();
        //获取所有的数据库表信息
        ResultSet rs = metaData.getTables(dbName!=null?dbName:conn.getCatalog(), "%", "%", new String[]{
   "TABLE"});
        while (rs.next()) {
   
            TableClass tableClass = new TableClass();
            tableClass.setTableName(rs.getString(3));
            tableClass.setTableComment(rs.getString(5));
            list.add(tableClass);
        }
        return list;
    }

    /**
     *  获取某张表的所有列
     * @param tableName
     * @return
     * @throws Exception
     */
    public List<ColumnClass> getAllColumns(String tableName) throws Exception {
   
        List<ColumnClass> list = new ArrayList<>();
        //获取链接
        Connection conn = getConnection();
        //获取元数据
        DatabaseMetaData metaData = conn.getMetaData();
        //获取所有的数据库某张表所有列信息
        ResultSet rs = metaData.getColumns(dbName!=null?dbName:conn.getCatalog(), "%", tableName,"%");

        while(rs.next()) {
   
            ColumnClass columnClass = new ColumnClass();
            columnClass.setColumnName(rs.getString("COLUMN_NAME"));
            columnClass.setColumnType(rs.getString("TYPE_NAME"));
            columnClass.setColumnComment(rs.getString("REMARKS"));
            columnClass.setChangeColumnName(StrUtil.changeColumnStr(rs.getString("COLUMN_NAME")));
            list.add(columnClass);
        }
        return list;
    }

    /**
     * 关闭链接
     */
    public void closeConnection(){
   
        try {
   
            connection.close();
        } catch (SQLException e) {
   
            e.printStackTrace();
        }
    };

}

(2)字符串处理工具类

package freemarker.util;

/**
 * 字符串处理工具类
 */
public class StrUtil {
   
    /**
     * 去掉下划线转驼峰  user_name  -> userName
     * @param str
     * @return
     */
    public static String changeColumnStr(String str) {
   
        String name = str;
        if (name.indexOf("_") > 0 && name.length() != name.indexOf("_") + 1) {
   
            int lengthPlace = name.indexOf("_");
            name = name.replaceFirst("_", "");
            String s = name.substring(lengthPlace, lengthPlace + 1);
            s = s.toUpperCase();
            str = name.substring(0, lengthPlace) + s + name.substring(lengthPlace + 1);
        } else {
   
            return str;
        }
        return changeColumnStr(str);
    }
    /**
     * 去掉下划线转驼峰  tb_user  -> TbUser
     * @param str
     * @return
     */
    public static String changeTableStr(String str) {
   
        String s = changeColumnStr(str);
        return s.substring(0,1).toUpperCase()+s.substring(1);
    }
}

(3)FreeMarker模版工具类

package freemarker.util;

import freemarker.cache.FileTemplateLoader;
import freemarker.cache.NullCacheStorage;
import freemarker.template.Configuration;
import freemarker.template.Template;
import freemarker.template.TemplateExceptionHandler;

import java.io.File;
import java.io.IOException;
import java.io.UnsupportedEncodingException;

/**
 * FreeMarker模版工具类
 */
public class FreeMarkerTemplateUtils {
   
    private FreeMarkerTemplateUtils(){
   }
    private static final Configuration CONFIGURATION = new Configuration(Configuration.VERSION_2_3_22);
    static{
   
        //ClassTemplateLoader方式:需要将模版放在FreeMarkerTemplateUtils类所在的包,加载模版时会从该包下加载
        //CONFIGURATION.setTemplateLoader(new ClassTemplateLoader(FreeMarkerTemplateUtils.class,""));

        try {
   
            String path = java.net.URLDecoder.decode(FreeMarkerTemplateUtils.class.getClassLoader().getResource("").getPath(),"utf-8");
            //FileTemplateLoader方式:需要将模版放置在classpath目录下 目录有中文也可以
            CONFIGURATION.setTemplateLoader(new FileTemplateLoader(new File(path)));
        } catch (UnsupportedEncodingException e) {
   
            e.printStackTrace();
        } catch (IOException e) {
   
            e.printStackTrace();
        }
        CONFIGURATION.setDefaultEncoding("UTF-8");
        CONFIGURATION.setTemplateExceptionHandler(TemplateExceptionHandler.RETHROW_HANDLER);
        CONFIGURATION.setCacheStorage(NullCacheStorage.INSTANCE);
    }
 
    public static Template getTemplate(String templateName) throws IOException {
   
        try {
   
            return CONFIGURATION.getTemplate(templateName);
        } catch (IOException e) {
   
            throw e;
        }
    }
 
    public static void clearCache() {
   
        CONFIGURATION.clearTemplateCache();
    }
}
4.2.3 实体类

(1)表实体类

package freemarker.param;

import lombok.Data;

@Data
public class TableClass {
   
    /**
     * 表名 tb_user
     **/
    private String tableName;

    /**
     *  表注释
     **/
    private String tableComment;

}

(2)列实体类

package freemarker.param;

import lombok.Data;

@Data
public class ColumnClass {
   
    /**
     * 数据库字段名称 user_name
     **/
    private String columnName;
    /**
     * 数据库字段类型
     **/
    private String columnType;
    /**
     * 数据库字段首字母小写且去掉下划线字符串 userName
     **/
    private String changeColumnName;
    /**
     * 数据库字段注释
     **/
    private String columnComment;

}

(3)模版相关参数类

package freemarker.param;

import lombok.Data
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值