JFinal生成指定数据库表javabean

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);
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值