欢迎投稿

今日深度:

kettle中javascript步骤错误处理,kettlejavascript

kettle中javascript步骤错误处理,kettlejavascript


javascript步骤错误处理

 

       如果你熟悉kettle转换的错误特性,你可能想知道在javascript步骤如何使用。支持错误机制的步骤用户界面机制是相同的,在javascript步骤右击,选择“定义错误处理”启用错误处理并配置。javascript代码可以识别错误行,并将他们转发到配置的错误处理步骤,通过使用_step_对象的putError()方法,需要以下几个参数:

1)    RowMetaInterface对象描述行结构

2)    当前的错误行

3)    在此行检测的错误数

4)    错误描述字符串(错误消息)

5)    引起错误的字段名称(字符串)

6)    错误代码(字符串)

 

通常情况下,原始的,未经修改的输入行被传递到错误处理步骤。因此,前两个参数通常被指定为getInputRowMeta()和row。其他参数取决于你想怎么具体描述所遇到的错误。javascript步骤定义错误处理配置可以配置那些字段输出到错误处理步骤。


这个转换的例子首先生成随机字符串。为了说明目的,javascript步骤判断前面生成的字符缺少字母'a'和'K'就报错,每个缺少字母就产生一个错误。

javascript步骤包含以下代码:


 

varshould_error_on_a= (value.indexOf("a") == -1)?1:0;

varshould_error_on_k= (value.indexOf("k") == -1)?1:0;

  

try{

  

    if(should_error_on_a== 1 && should_error_on_k == 1){

        throw{

            message:"Value must contain 'a' and 'k'",

            nr_errors:2,

            field:"value",

            errcode:"ERR:003"

        }

    }

    elseif(should_error_on_a== 1){

        throw{

            message:"Value must contain 'a'",

            nr_errors:1,

            field:"value",

            errcode:"ERR:001"

        }

    }

    elseif(should_error_on_k== 1){

        throw{

            message:"Value must contain 'k'",

            nr_errors:1,

            field:"value",

            errcode:"ERR:002"

        }

    }

    //continue normally, passing the row on to the next step

    trans_Status= CONTINUE_TRANSFORMATION;

  

}

catch(e){

    //divert the current row to the error step and do not pass anything to thenext  step

    _step_.putError(getInputRowMeta(),row, e.nr_errors, e.message, e.field, e.errcode);

    trans_Status= SKIP_TRANSFORMATION;

}


kettle 42 连接数据库错误,帮忙,如图所示

应该是Mysql数据库配置的问题吧,网上有对应的解放方法,如:
解决方法:
1。 改表法。可能是你的帐号不允许从远程登陆,只能在localhost。这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称"%"
mysql -u root -pvmwaremysql>use mysql;mysql>update user set host = '%' where user = 'root';mysql>select host, user from user;
2. 授权法。例如,你想myuser使用mypassword从任何主机连接到mysql服务器的话。
这个不是Kettle的问题。
 

kettle连接sql server2008报错报不存在实例yss_pc,但是启动SQL Server Management Studio存在实例yss_pc

错误说明是说你的链接数据库时报错啊~
链接驱动异常啊~
你最好是先检查一下你的链接语句,在确认你的链接端口之类的,在看看数据驱动是否有问题啊
 

www.htsjk.Com true http://www.htsjk.com/shujukunews/4105.html NewsArticle kettle中javascript步骤错误处理,kettlejavascript javascript步骤错误处理 如果你熟悉kettle转换的错误特性,你可能想知道在javascript步骤如何使用。支持错误机制的步骤用户界面机制是相同的,...
评论暂时关闭