package cn.pangpython.model;
import javax.sql.DataSource;
import com.jfinal.kit.PathKit;
import com.jfinal.kit.Prop;
import com.jfinal.kit.PropKit;
import com.jfinal.plugin.activerecord.generator.Generator;
import com.jfinal.plugin.c3p0.C3p0Plugin;
/** * GeneratorDemo * 来自JFinal官方的生成器 * */
public class _JFinalGenerator {
public static DataSource getDataSource() {
//加载配置文件
Prop p = PropKit.use("SystemConfig.txt");
//创建c3p0连接
C3p0Plugin c3p0Plugin = new C3p0Plugin(p.get("jdbcUrl"), p.get("user"), p.get("password"));
c3p0Plugin.start();
return c3p0Plugin.getDataSource(); }
public static void main(String[] args) {
// base model 所使用的包名
String baseModelPackageName = "cn.pangpython.model.base";
// base model 文件保存路径
String baseModelOutputDir = PathKit.getWebRootPath() + "/../src/cn/pangpython/model/base";
// model 所使用的包名 (MappingKit 默认使用的包名)
String modelPackageName = "cn.pangpython.model";
// model 文件保存路径 (MappingKit 与 DataDictionary 文件默认保存路径)
String modelOutputDir = baseModelOutputDir + "/..";
// 创建生成器
Generator gernerator = new Generator(getDataSource(), baseModelPackageName, baseModelOutputDir, modelPackageName, modelOutputDir);
// 设置数据库方言
//gernerator.setDialect(new MysqlDialect());
//添加需要生成的表名 MyMetaBulider metaBulider = new MyMetaBulider(getDataSource()); //数据库表名包含字段(可以是数据库全名,否则所有包含字段的表都将生成) metaBulider.setTablePrefix("数据库目标表名"); generator.setMetaBuilder(metaBulider);
// 添加不需要生成的表名
//gernerator.addExcludedTable("adv");
// 设置是否在 Model 中生成 dao 对象
gernerator.setGenerateDaoInModel(true);
// 设置是否生成字典文件
gernerator.setGenerateDataDictionary(false);
// 设置需要被移除的表名前缀用于生成modelName。例如表名 "osc_user",移除前缀 "osc_"后生成的model名为 "User"而非 OscUser
//gernerator.setRemovedTableNamePrefixes("t_");
// 生成
gernerator.generate();
}
}
package com; import com.jfinal.plugin.activerecord.generator.MetaBuilder; import javax.sql.DataSource; public class MyMetaBulider extends MetaBuilder { //public String tablePrefix = "contact_temp"; public String tablePrefix; public MyMetaBulider(DataSource dataSource){ super(dataSource); } public void setTablePrefix(String tablePrefix){ this.tablePrefix = tablePrefix; } @Override protected boolean isSkipTable(String tableName){ //return !tableName.equals(tablePrefix); return !tableName.contains(tablePrefix); } }