Domo IDEAs Conference - Beast Modes - Time Difference Formatting
Greetings! This is another post highlighting a beast mode from my Domo IDEAs conference session. This one covers how to format a different between two date time values.
Problem:
How can I display the difference between two timestamps values in a human readable format?
Solution:
We can utilize the UNIX_TIMESTAMP
function to calculate the number of seconds which have elapsed since January 1st 1970 12:00AM. By subtracting these these two values it will give us the number of seconds between the two timestamps. We then can do some simple division to determine the number of days, hours, minutes and seconds.
Days:
-- Description: -- UNIX_TIMESTAMP returns the number of seconds since 1970-01-01 -- UNIX_TIMESTAMP - UNIX_TIMESTAMP returns the number of seconds between the right now and the value in `dt` -- Then divide by 24*60*60 = 86400 (number of seconds in a day) -- Floor returns the whole number of days that have elapsed FLOOR((UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`)) / (24*60*60))
Hours:
-- Description: -- Determine the number of hours ago (partial days) FLOOR( -- After taking out whole days get the remainder of seconds. 86400 seconds = 1 day (MOD(UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`), 86400)) -- Finally divide by 60*60 = 3600 to convert to hour units / 3600)
Minutes:
-- Description: -- Determine the number of remaining minutes to go in our timespan (since now) -- Divide by whole hours (3600 seconds) and get the remainer seconds using MOD FLOOR((MOD(UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`), 3600)) -- Finally convert to minute units / 60)
Seconds:
-- Description: -- Simply divie by 60 and get the remaining seconds using Modulo operation (MOD function). FLOOR(MOD(UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`), 60)) -- Whole elapsed seconds
Finally we can combine all of the beast modes together to make a single string containing the formatted difference:
-- Author: -- Created: -- Last Modified: -- Description: -- UNIX_TIMESTAMP returns the number of seconds since 1970-01-01 -- Using some simple math we can calculate the time since a specific date. -- For a more detailed breakdown of what each step is doing refer to Days Ago, Hours Ago, Minutes Ago or Seconds Ago -- This concatenates all of those values together in a readable format. CONCAT( -- Simplify formatting of negative time differences by conditionally adding a negative -- and then subsequently taking the absolute values. -- This is to avoid getting times like -1d -12:-9:-11 -- and instead format like -1d 12:9:11 CASE WHEN CURRENT_TIMESTAMP() <= `dt` THEN '-' ELSE '' END, -- Days ABS(FLOOR((UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`)) -- - MOD(UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`), 86400)) / 86400)), 'd ', -- Hours ABS(FLOOR( (MOD(UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`), 86400)) -- - MOD(MOD(UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`), 86400), 3600)) / 3600)), ':', -- Minutes ABS(FLOOR((MOD(UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`), 3600)) -- - MOD(MOD(UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`), 3600), 60)) / 60)), ':', -- Seconds ABS(FLOOR(MOD(UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`), 60))) )
**Did this solve your problem? Accept it as a solution!**
Comments
-
Hi @GrantSmith ,
I've just watched your Domo Ideas Exchange session. Thanks for the great work! :D
I noticed your Beast Mode was returning incorrect values for future dates, and while I was at it I also simplified the code to make it more readable (at least for me). Here's my proposal:
CONCAT(
CASE WHEN CURRENT_TIMESTAMP() <= `dt` THEN '-' ELSE '' END,
-- Days
FLOOR ( ABS ( ( UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`) ) ) / 86400 ),
'd ',
-- Hours, Minutes and Seconds
SEC_TO_TIME ( ABS ( MOD ( UNIX_TIMESTAMP(CURRENT_TIMESTAMP()) - UNIX_TIMESTAMP(`dt`), 86400 ) ) )
)
I didn't update the Beast Mode in the Dojo instance, though. Please let me know if you want me to add this Beast Mode as an alternative approach in the original DataSet :)
Best,
Amedeo
2 -
You're indeed correct there was an issue with future dates. Your version corrects this issue and I've updated the beast mode on the dojo instance. Thanks for your contribution!
**Was this post helpful? Click Agree or Like below**
**Did this solve your problem? Accept it as a solution!**2 -
Here's a link to the video of my session outlining this beast mode: https://www.youtube.com/watch?v=gO8OLpsAk4M&index=6
**Was this post helpful? Click Agree or Like below**
**Did this solve your problem? Accept it as a solution!**1
Categories
- All Categories
- 1.8K Product Ideas
- 1.8K Ideas Exchange
- 1.6K Connect
- 1.2K Connectors
- 300 Workbench
- 6 Cloud Amplifier
- 9 Federated
- 2.9K Transform
- 102 SQL DataFlows
- 626 Datasets
- 2.2K Magic ETL
- 3.9K Visualize
- 2.5K Charting
- 755 Beast Mode
- 61 App Studio
- 41 Variables
- 693 Automate
- 178 Apps
- 456 APIs & Domo Developer
- 49 Workflows
- 10 DomoAI
- 38 Predict
- 16 Jupyter Workspaces
- 22 R & Python Tiles
- 398 Distribute
- 115 Domo Everywhere
- 276 Scheduled Reports
- 7 Software Integrations
- 130 Manage
- 127 Governance & Security
- 8 Domo Community Gallery
- 38 Product Releases
- 11 Domo University
- 5.4K Community Forums
- 40 Getting Started
- 30 Community Member Introductions
- 110 Community Announcements
- 4.8K Archive