What could cause the DateTime Stamp date to be wrong

I use a timesheet table with a field called TimeStamp set to default to NOW() with a Show of false. This week I noticed that one of the employees looked like he entered his day sheet the day before the day he worked but when I looked through the Version history on the GSheet, it is clear that he entered it on the correct date but the TimeStamp was incorrect. What could cause this behaviour? How reliable is NOW()?

Solved Solved
0 4 567
1 ACCEPTED SOLUTION

This approach to capture the server time was suggested by @Steve in the thread mentioned below. To capture server time, please use following approach. However please be aware that for this approach, the app needs to be online.

  1. Create an action that sets the timestamp column to NOW()
  2. Call this action in a data change workflow. The workflow update event will be โ€œAdds Onlyโ€

There had been a very substantial discussion on a relevant topic sometime ago, please take a look at it.

View solution in original post

4 REPLIES 4

As per my understanding, the NOW() from AppSheet is reliable. Typically, the NOW() uses the device date time. So if the userโ€™s device is set at a day before at whatever time, I believe it will use that deviceโ€™s timestamp as NOW(). You can test it by setting your deviceโ€™s timestamp to a previous day ( or any other day than correct day) and also some other time than the correct time.

I believe you can circumvent that issue by using a workflow ( or now automation) to capture the server time. The workflow can trigger on Adds only and it can call an action to set the timestamp field to NOW().

Thanks Suvrutt. Not sure how to capture the server time. The way I have set this up is that Timestamp is set to NOW() as the initial value. How would I go about capturing the server time instead of the device time?

The employee this happened with is far from tech savvy and itโ€™s the first time I;ve seen the issue. I can only assume he hasnโ€™t set his phone to auto update the time. The problem is that we pay a bonus if they get their timesheets in on the same day they worked so I need to be robust.

This approach to capture the server time was suggested by @Steve in the thread mentioned below. To capture server time, please use following approach. However please be aware that for this approach, the app needs to be online.

  1. Create an action that sets the timestamp column to NOW()
  2. Call this action in a data change workflow. The workflow update event will be โ€œAdds Onlyโ€

There had been a very substantial discussion on a relevant topic sometime ago, please take a look at it.

Thanks Suvrutt, Appreciate your guidance, yet again. I will likely add a column for local add time and another for sync time to see how often, and how long, thereโ€™s a descrepancy for.

Top Labels in this Space