cancel
Showing results for 
Search instead for 
Did you mean: 

Transformation rules inside mapper snap not exported to output file

darshthakkar
Valued Contributor

Hi Team,

I have found one of the transformational rules applied on “date field” not getting exported to the final output file (i.e. excel file) when the pipeline has been executed.
Output preview on the snap does show the right data (i.e. expected one), pipeline validation also shows the right data however the file which gets generated after pipeline execution doesn’t get those details.

I have tried the following:

  • validated pipeline via shift+validate
  • tweak the transformation rule, save the pipeline and check the output in the preview
  • validated the preview file (with default 50 records)
  • deleted the file generated by “validate & execute” snap on File writer with default 50 records so that new instance of data comes in
  • executed the pipeline with different file name multiple times

It’s a simple pipeline consisting of

            Snowflake Execute --> Mapper --> Excel Formatter --> File Writer

Sharing some screenshots to help it understand better:
(1) Pipeline with 4 snaps
image

(2) Snowflake execute output preview in JSON format (highlighted yellow fields needs transformation)
image

(3) Transformation Rules on Date fields
image

(4) Transformation Rule: $Expire_Date.toString().replace('{Timestamp=',"").replace('.000+0000}',"Z")

image

(5) Output preview after transformational rule
image

(6) Mapper output preview shows different data
image

→ I’ve observed certain times that the transformation rules won’t work so I go inside the mapper, modify the rule a bit, bring it back to default rule so that I can save it (save is not enabled if there is no change thus this workaround)

(7) As shift+validate didn’t work, had to change the transformation rule, save it and then this is the output preview on mapper snap:
image

(8) Settings under excel formatter snap for reference:
image

(9) Settings under File Writer snap for reference:
image

(10) File generated with default 50 records due to validate & execute on File writer snap
image

(11) Downloaded the file that gets generated in step 10 and below is the output (expected)
image

(12) Executed Pipeline
image

(13) Output File of Executed pipeline
image


image


image

I’ve seen this happening numerous times particularly to fields containing timestamp in other pipelines too, am I doing something wrong over here? Any settings that needs to be changed either in Mapper, Excel Formatter or File Writer snap?

Thanking in advance for your valuable time and suggestions on this one.

Best Regards,
DT

1 ACCEPTED SOLUTION

ptaylor
Employee
Employee

The Snowflake snaps have a setting called Handle Timestamp and Date Time Data. Unfortunately, its default setting, Default Date Time format in UTC Time Zone, has less-than-ideal behavior. The object type of the timestamp objects is java.sql.Timestamp, which will result in the odd inconsistencies you’re seeing between validation vs execution, and it’s also not a very usable type on the SnapLogic expression language.

I suggest changing this setting to the other option, SnapLogic Date Time format in Regional Time Zone. This will convert the timestamps to the type org.joda.time.DateTime, the type that the SnapLogic EL functions are designed to deal with.

This option will also produce a DateTime with the default time zone of the plex node, which can complicate things if the node’s default timezone isn’t UTC. But based on what you’ve shown, your node’s default timezone is UTC, so this shouldn’t be a problem for you, fortunately.

After changing that setting, try using an expression like $Expire_Date.toLocaleDateTimeString({format: "yyyy-MM-dd'T'HH:mm:ss'Z'"}).

Hope that helps.

View solution in original post

23 REPLIES 23

I wouldn’t say either is clearly better than the other, but there’s certainly no reason to use both. Pick one.

Actually, there’s an assumption with both of these expressions that the platform’s default time zone is UTC. If that were to change, the first expression’s replace wouldn’t do anything because the string wouldn’t end with ‘Z’. That’s probably a good thing, since you’d discover the problem more quickly. The second expression would just format the timestamp as if it were in UTC when it’s really not, so this would be a much more subtle problem to detect and fix.

Super, thanks @ptaylor for your assistance on this one. Your help is really appreciated.

darshthakkar
Valued Contributor

Summarizing the solution as per this use case:

  1. Snowflake execute snap Settings > Handle Timestamp and Date Time Data > SnapLogic Date Time format in Regional Time Zone
  2. Use either of the below expressions in mapper snap:
    a) $Expire_Date.toLocaleDateTimeString({format: "yyyy-MM-dd'T'HH:mm:ss'Z'"})
    b) $Expire_Date.toString().replace('.000Z',"Z")

Works only for this use case, before using expressions, check the raw data and then put the transformation rule as per the raw data and expected data.

Signing off from this thread. Thanks again everyone (@j.angelevski, @robin and @ptaylor) for your help.