我有一個非規範化的類似問題。我有一個/etc/group
文件,其結構類似於group:gid:member1,member2,....
,我用User Defined Java Class
組件反規格化了它,所以最後我有group,gid,member
。我知道你需要另一個方向,但它可能是一個很好的起點。這裏是來源:
public boolean processRow(StepMetaInterface smi, StepDataInterface sdi) throws KettleException
{
// boilerplate
Object[] r = getRow();
if (r == null) {
setOutputDone();
return false;
}
if(first)
first = false;
String tmp = get(Fields.In, "members").getString(r);
if(null==tmp)
return true;
String accounts[] = tmp.split(",");
for(int i=0; i<accounts.length; ++i){
Object[] out_row = RowDataUtil.allocateRowData(data.outputRowMeta.size());
for (int j=0; j<r.length; ++j)
out_row[j] = r[j];
String account = accounts[i];
get(Fields.Out, "account").setValue(out_row,account);
putRow(data.outputRowMeta, out_row);
}
return true;
}