用JFinalDemoGenerator生成model问题

潜水兔 发布于 2016/09/11 17:13
阅读 830
收藏 0

@JFinal 请问一下 

我的数据库是Mysql 下面是我的url配置

jdbc.properties

#mysql#
username=root
password=root
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/test?autoReconnect=true&useUnicode=true&characterEncoding=UTF8
devMode =true

package cn.wawi.common;

import javax.sql.DataSource;

import com.jfinal.kit.PathKit;
import com.jfinal.kit.PropKit;
import com.jfinal.plugin.activerecord.dialect.MysqlDialect;
import com.jfinal.plugin.activerecord.generator.Generator;
import com.jfinal.plugin.c3p0.C3p0Plugin;

/**
 * 在数据库表有任何变动时,运行一下 main 方法,极速响应变化进行代码重构
 */
public class _JFinalGenerator {
	
	public static DataSource getDataSource() {
		PropKit.use("jdbc.properties");
		C3p0Plugin c3p0Plugin = DefaultConfig.createC3p0Plugin();
		c3p0Plugin.start();
		return c3p0Plugin.getDataSource();
	}
	public static void main(String[] args) {
		// base model 所使用的包名
		String baseModelPackageName = "cn.test.model.data.base";
		// base model 文件保存路径
		String baseModelOutputDir = PathKit.getWebRootPath() + "/../src/cn/test/model/data/base";
		
		// model 所使用的包名 (MappingKit 默认使用的包名)
		String modelPackageName = "cn.test.model.data";
		// model 文件保存路径 (MappingKit 与 DataDictionary 文件默认保存路径)
		String modelOutputDir = baseModelOutputDir + "/..";
		// 创建生成器
		Generator gernerator = new Generator(getDataSource(), baseModelPackageName, baseModelOutputDir, modelPackageName, modelOutputDir);
		gernerator.setDialect(new MysqlDialect()); 
		// 添加不需要生成的表名
//		gernerator.addExcludedTable("view_","sys_","sys_role_privilege","sys_user_role");
		// 设置是否在 Model 中生成 dao 对象
		gernerator.setGenerateDaoInModel(true);
		// 设置是否生成字典文件
		gernerator.setGenerateDataDictionary(false);
		// 设置需要被移除的表名前缀用于生成modelName。例如表名 "osc_user",移除前缀 "osc_"后生成的model名为 "User"而非 OscUser
//		gernerator.setRemovedTableNamePrefixes("t_","sys_");
		// 生成
		gernerator.generate();
	}
}
但是系统报错:错误信息如下

Build TableMeta ...
Generate base model ...
Exception in thread "main" java.lang.NullPointerException
    at com.jfinal.kit.StrKit.firstCharToUpperCase(StrKit.java:41)
    at com.jfinal.plugin.activerecord.generator.BaseModelGenerator.genSetMethodName(BaseModelGenerator.java:100)
    at com.jfinal.plugin.activerecord.generator.BaseModelGenerator.genBaseModelContent(BaseModelGenerator.java:80)
    at com.jfinal.plugin.activerecord.generator.BaseModelGenerator.generate(BaseModelGenerator.java:70)
    at com.jfinal.plugin.activerecord.generator.Generator.generate(Generator.java:216)
    at cn.wawi.common._JFinalGenerator.main(_JFinalGenerator.java:44)


加载中
0
JFinal
JFinal
    异常表明是 genSetMethodName(...) 的参数 columnMeta.attrName 值为 null,建议调试跟踪一下, mysql 之下生成器抛异常,这个是极其少见的,请确保使用的是最新版本 jfinal 2.2 ,并且生成器是否有被改造过?
0
潜水兔
潜水兔

引用来自“JFinal”的评论

    异常表明是 genSetMethodName(...) 的参数 columnMeta.attrName 值为 null,建议调试跟踪一下, mysql 之下生成器抛异常,这个是极其少见的,请确保使用的是最新版本 jfinal 2.2 ,并且生成器是否有被改造过?
我放入的是官网下载的jfinal-2.2-bin.jar。这个错误我调试了下,没看到在buildColumnMetas()里和其他地方找到有赋予attrName值。
JFinal
JFinal
回复 @潜水兔 : 单独回复一行,这样有助于有需要的朋友看得到
潜水兔
潜水兔
回复 @JFinal : 谢谢...解决了,是我用的的引入MetaBuilder.java有错误,换成demo里面的就好了...
JFinal
JFinal
columnMeta.attrName 值是在 MetaBuilder.java 中赋值的,在其中设置断点跟踪一下
返回顶部
顶部