Jfinal Generator 不需要生成带某个前缀的表名数组的方法

package com.demo.common.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;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
/**
 * GeneratorDemo
 */
public class GeneratorDemo {
	
	public static DataSource getDataSource() {
		Prop p = PropKit.use("a_little_config.txt");
		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 = "com.demo.common.model.base";
		// base model 文件保存路径
		String baseModelOutputDir = PathKit.getWebRootPath() + "/../src/com/demo/common/model/base";
		
		// model 所使用的包名 (MappingKit 默认使用的包名)
		String modelPackageName = "com.demo.common.model";
		// model 文件保存路径 (MappingKit 与 DataDictionary 文件默认保存路径)
		String modelOutputDir = baseModelOutputDir + "/..";
		
		// 创建生成器
		Generator gernerator = new Generator(getDataSource(), baseModelPackageName, baseModelOutputDir, modelPackageName, modelOutputDir);
		// 设置数据库方言
		gernerator.setDialect(new MysqlDialect());
		// 添加不需要生成的表名
		gernerator.addExcludedTable(getExcTab("compact_"));
		// 设置是否在 Model 中生成 dao 对象
		gernerator.setGenerateDaoInModel(true);
		// 设置是否生成字典文件
		gernerator.setGenerateDataDictionary(false);
		// 设置需要被移除的表名前缀用于生成modelName。例如表名 "osc_user",移除前缀 "osc_"后生成的model名为 "User"而非 OscUser
		gernerator.setRemovedTableNamePrefixes("t_");
		// 生成
		gernerator.generate();
	}
	
	private static String[] getExcTab(String preName){
		String sql="SELECT table_name from information_schema.tables WHERE table_name LIKE '"+preName+"%'";
		List<String> list = new ArrayList<String>();
		Connection conn = null;
		try {
			conn = getDataSource().getConnection();
			Statement stmt = conn.createStatement();
			ResultSet rs=stmt.executeQuery(sql);
			while (rs.next()) {
				list.add(rs.getString(1));
			}
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally{
			try {
				conn.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
		
		String[] s=new String[list.size()];
		for (int i = 0; i < list.size(); i++) {
			s[i]= list.get(i);
		}
		return s;
	}
}



一开始查询的时候用Db+Record方法。。。
创建自动生成代码的java文件。 (1)先创建一个java Project,然后next,然后选择Create project from template模版, 选中后,点击Java Hello World模版,然后next,出现定义Project名,写上自己定义的文件名(提示:automatic 自动的,generate 生成,code 代码),然后finsh,这就完成了自动生成文件的创建。 图片1.png 图片2.png 导入相关的lib。 (1) 点击项目,然后创建一个lib的目录,然后将mybatis的三个jar包和关于打印 日志的log4j的jar包导入。 图片3.png (2) 然后选中导入所有的jar包,然后右击,选中Add as lib..,然后在 level 选项 中选择Project Library,这就完成了相关自动生成代码的包的导入。 图片4.png (3) 完成后的目录展示 图片5.png 导入generatorConfig.xml (1) 将generatorConfig.xml放在项目的目录下,与src,lib同一级目录。 图片6.png 修改generatorConfig.xml配置文件。 (1) 修改连接数据库的主机名,数据库。 <!--数据库连接的信息:驱动类、连接地址、用户名、密码 --> ​ <jdbcConnection driverClass="com.mysql.jdbc.Driver" ​ connectionURL="jdbc:mysql://localhost:3306/mybatis" ​ userId="root" password="123456"> ​ </jdbcConnection> connectionURL:修改的是自己连接数据的主机(如果是本机用localhost,如果是远程的话,就输入远程的ip地址)和数据库的名字 userId: 数据库的用户名 Password: 数据库的密码 (2) 修改连接数据库的表名 <!-- 指定数据库 --> ​ <table schema="" tableName="batis"></table> ​ tableName: 连接数据库中的表名。 如果有多个表名需要连接,可以写多个我们这样的标签,修改tableName中的表名。 (3) 修改自动生成的bean类(或者说Po类,model类)的位置。 <!-- targetProject:生成bean类的位置 --> ​ <javaModelGenerator targetPackage="cn.kz.com.po" ​ targetProject=".\src"> ​ <!-- enableSubPackages:是否让schema作为包的后缀 --> <property name="enableSubPackages" value="false" /> ​ <!-- 从数据库返回的值被清理前后的空格 --> ​ <property name="trimStrings" value="true" /> ​ </javaModelGenerator> ​ targentPackage: 就是我们生成bean类的目录和位置,(生成的包在src/cn/kz/com/po) targetProject: 如果值为”.\src” ,就是将文件创建在src根目录下 (4) 修改生成mapper文件的位置 <!-- targetProject:mapper映射文件生成的位置 --> ​ <sqlMapGenerator targetPackage="cn.kz.com.mapper" ​ targetProject=".\src"> ​ <!-- ​ enableSubPackages:是否让schema作为包的后缀 --> ​ <property name="enableSubPackages" value="false" /> ​ </sqlMapGenerator> ​ (5) 修改生成mapper接口的位置 <!-- targetPackage:mapper接口生成的位置 --> ​ <javaClientGenerator type="XMLMAPPER" targetPackage="cn.kz.com.mapper" ​ targetProject=".\src"> ​ <!-- ​ enableSubPackages:是否让schema作为包的后缀 --> ​ <property name="enableSubPackages" value="false" /> ​ </javaClientGenerator> 将GeneratorSqlmap 类复制到src下。 (1) 如果类不报红,就直接运行(运行前,记得将数据库打开),然后运行如果出现了生成的包和文件,就说明成功,虽然控制台会显示一些红色的日志,但无关紧要。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值