Having a scenario that source data like below in table
data:image/s3,"s3://crabby-images/2e848/2e848a17af5632e7f3fc65d652cee875065a7cd4" alt="enter image description here"
Target Output required as
data:image/s3,"s3://crabby-images/0a2e0/0a2e0b74819d76e5412e164039b17fd3b8d07f26" alt="enter image description here"
You can use the Java code in this example to create and compile an active Java transformation
data:image/s3,"s3://crabby-images/fa698/fa6985d19fc388c5b62ff41f0993ecdef5176fa5" alt="enter image description here"
Create a java transformation with one input and one output field as shown in below snapshot.
data:image/s3,"s3://crabby-images/150a8/150a8ea4bb319be4e0089329f4c1737e4a7e80bf" alt="enter image description here"
Connect concatenated fields (A#B#C) from expression transformation to FLD_INPUT of java transformation
Now go to java code tab and paste below code
String[] str_fld_nm=FLD_INPUT.split("#");
for(inti=0; i < str_fld_nm.lenght; i++){
FLD_OUTPUT =str_fld_nm[i];
generateRow();
}
It is using java functionality of array to break input field and multiple fields and then use generateRow () to produce multiple rows.
data:image/s3,"s3://crabby-images/3d9af/3d9af4a3ded07d0ca908a343ee24f926ffba9aae" alt="enter image description here"
Now connect FLD_OUTPUT to target, so output will be as shown below.
data:image/s3,"s3://crabby-images/53c5d/53c5d161d28948088a79f2a1ae993b43114bed1c" alt="enter image description here"
Core functionality is using Java functionality, to break concatenated string into multiple fields and use generateRow() to produce multiple rows.
By using Router & Normalizer transformations also we can convert rows into columns.
data:image/s3,"s3://crabby-images/eae85/eae85fd736169e54a48c81bc9cd21bb1db6e8c13" alt="enter image description here"