本文主要讲述Kettle中参数的分类,并针对每一类参数的使用进行说明。
关于变量的使用介绍,请参考历史文章:Kettle变量和参数介绍系列文章1-变量的使用
参数的分类
在Kettle中参数主要可以分为2类,分别是位置参数(Argument)和命名参数(Parameter)。两者的表现形式如下图所示:
位置参数没有参数名称,只能通过参数的位置顺序进行识别,而命名参数有具体的参数名称,是通过参数名称进行识别的。因此,命名参数像变量一样,可以在有效范围内被多次使用;而位置参数只能被其后的步骤使用一次,或通过“设置变量”组件把其转化为变量。
参数的使用
1、遵循“外部赋值,内部使用”的原则
变量可以在脚本文件执行过程中进行动态创建和赋值,而参数和变量的最大不同就是,需要在脚本文件执行前指定参数值,然后才能在程序内部执行时进行使用,也就是我们常说的“传参”。
传参的好处就是,我们可以根据具体的业务需求动态地指定对应的参数值,而不需要重新去编辑脚本文件,操作相对简单,且有利于执行程序的稳定和复用。
当然,对于命名参数,为了程序的高效运行,我们可以给其指定常用的默认值。位置参数在日常的使用频次相对较低,目前不支持默认值设置。
2、在哪里使用参数
位置参数和流字段(数据流中的字段)的使用类似,区别就是其是在程序执行前赋值的。
命名参数的使用和变量类似,在Kettle中带