Java 向 kettle8.0 传递参数总结

1.传递参数到转换中

1.1. 通过设置Trans的variable的key、value值

Java 向 kettle8.0 传递参数总结

1.2. 源码中,直接将我们的key、value存放到了全局的properties中

Java 向 kettle8.0 传递参数总结

1.3. 在转化中可直接通过EL表达式获取参数:${yourkey}

Java 向 kettle8.0 传递参数总结

Java 向 kettle8.0 传递参数总结

1.4. 通过设置转换中的parameterValue的key、value值

Java 向 kettle8.0 传递参数总结

1.5. params是从我们定义的命名参数中解析的map

Java 向 kettle8.0 传递参数总结

1.6. 命名参数的key必须和我们传入的key值向同才能将value值存放至params中,在kettle中同样通过EL表达式获取数据${yourkey}

Java 向 kettle8.0 传递参数总结

2. 传递参数到作业中

2.1. 通过设置全局的properties将我们的参数传递给kettle,如果作业中包含了转换,需要保证key值不能冲突

Java 向 kettle8.0 传递参数总结

2.2. 通过设置JobMeta的parameterValue可将参数传递给kettle,创建JobMeta时kettle会解析对应得xml格式的.kjb文件,并初始化命名参数的map,创建Job对象kettle并不会像创建Trans那样将TransMeta中的命名参数复制给Trans,所以此时的Job中的命名参数size为0,如果通过job.setParameterValue()函数并不能将我们的参数传递给kettle。

Java 向 kettle8.0 传递参数总结

2.3. kettle源码中,初始value值为空字符串,需要在job中设定命名参数的变量名作为key值才能将自己的参数对应传递给kettle,接下来在对应需要使用的地方用EL表达式即可获取${yourkey}

Java 向 kettle8.0 传递参数总结