3. USER DEFINED JAVA CLASS的使用
在kettle里面有时也需要调用外部的jar包里面的功能。这时就可以使用USER DEFINED JAVA CLASS组件。
这个组件使用的时候首先必须先设置输入的parameter. Tag的名字是自己给的,value的值是上一步的输出流。
parameter设置好之后,在窗口的左边才能出现输入字段列表,需要注意的是必须要能看到方法,如getString(),否则就是配的有问题:
接下来是编写java代码了:
首先是import 和 需要用到的变量定义
注意必须有这个public boolean processRow方法,kettle就是调用这个方法来执行user defined java class的。
在java代码中可以获取系统全局变量,也可以获取输入流中参数的值,如xml元素的值
然后是调用外部的jar包中的api:
首先需要把外部的jar包放到kettle安装目录的libext/文件夹下。
然后在user defined java class中import你所需要的api,如
import helloword;
helloword是我在jar包中定义的一个没有包结构的类。
然后可以在public boolean processRow方法使用helloword类中的方法:
new helloword().say_hello(xml);
关于如何设置user defined java class的返回,可以参考安装包中自带的例子:
在[kettle安装目录]/samples/transformations/User Defined Java Class-Calculate the date of Easter.ktr
在kettle里面有时也需要调用外部的jar包里面的功能。这时就可以使用USER DEFINED JAVA CLASS组件。

这个组件使用的时候首先必须先设置输入的parameter. Tag的名字是自己给的,value的值是上一步的输出流。

parameter设置好之后,在窗口的左边才能出现输入字段列表,需要注意的是必须要能看到方法,如getString(),否则就是配的有问题:

接下来是编写java代码了:
首先是import 和 需要用到的变量定义

注意必须有这个public boolean processRow方法,kettle就是调用这个方法来执行user defined java class的。
在java代码中可以获取系统全局变量,也可以获取输入流中参数的值,如xml元素的值

然后是调用外部的jar包中的api:
首先需要把外部的jar包放到kettle安装目录的libext/文件夹下。
然后在user defined java class中import你所需要的api,如
import helloword;
helloword是我在jar包中定义的一个没有包结构的类。
然后可以在public boolean processRow方法使用helloword类中的方法:
new helloword().say_hello(xml);
关于如何设置user defined java class的返回,可以参考安装包中自带的例子:
在[kettle安装目录]/samples/transformations/User Defined Java Class-Calculate the date of Easter.ktr