Best Way to Represent Dates as Columns in Table
First time I've come across a requirement like this. The goal is to see each month and have a calculation of the variance %increase or %decrease for that month and highlight them when it's a certain amount. The table view isn't necessarilly a requirement but the series contains over 200 records so i'm finding it hard to represent that in anything but a table, but even with the table i can't figure out the best way to get the dates across the top by month. Another problem this introduces is color rules. If I want to highlight any value over say +- 50% I can't because you choose a field, and choose color logic. I would have to have as many color rules as I do months of data (since each date might be its own column grouped monthly).
I tried experimenting with uncollapse columns but I don't want to have to define dates until the end of time as the value for a new column. Thoughts? See the attached small excerpt to see how it looks in Excel. Again, the "Account 1,2 3" is currently over 200 unique ones
**Make sure to like any users posts that helped you and accept the ones who solved your issue.**
Comments
-
Have you tried using a Sumo card? That is really the best way to pivot data in a visualization right now.
I ran into this issue in the opposite direction. I had a data set with the months listed as separate columns and I needed a flat file.
I was able to find a dynamic SQL statement to collapse the columns regardless of how many dates there were. Dynamic SQL is outside of my comfort zone, but I will share the code with you here to see if you can use it to help you "pivot" or uncollapse your data.
SELECT
GROUP_CONCAT(CONCAT('Select `Product Type`,',
QUOTE(COLUMN_NAME),
' AS `Date`, ',
'`',
COLUMN_NAME,
'` as `Revenue`',
'FROM original')
SEPARATOR ' UNION ALL ') AS product_info
FROM
INFORMATION_SCHEMA.COLUMNS
WHERE
TABLE_NAME = 'original'
AND COLUMN_NAME NOT IN ('Product Type');
CREATE PROCEDURE transpose()BEGIN
SELECT product_info into @sql2 FROM for_transpose;
SET @str=concat('create table products as ',@sql2);
PREPARE q from @str;
EXECUTE q;END
call transpose;
SELECT
`Product Type`,
STR_TO_DATE(REPLACE(`Date`, '/', ' '), '%m %d %Y') AS `Date`,
ROUND(`Revenue`, 2) AS `Revenue`
FROM
products
ORDER BY `Product Type` , `Date`These steps essentially do the opposite of what you are looking for, but perhaps they will help you get to your answer.
Good luck
“There is a superhero in all of us, we just need the courage to put on the cape.” -Superman2 -
Did the reply from @ST_-Superman-_ help? If so please mark it solved by clicking on the "Accept as Solution" button.
Thanks!
0
Categories
- All Categories
- 1.7K Product Ideas
- 1.7K Ideas Exchange
- 1.5K Connect
- 1.2K Connectors
- 292 Workbench
- 4 Cloud Amplifier
- 8 Federated
- 2.8K Transform
- 95 SQL DataFlows
- 603 Datasets
- 2.1K Magic ETL
- 3.7K Visualize
- 2.4K Charting
- 697 Beast Mode
- 43 App Studio
- 39 Variables
- 658 Automate
- 170 Apps
- 441 APIs & Domo Developer
- 42 Workflows
- 5 DomoAI
- 32 Predict
- 12 Jupyter Workspaces
- 20 R & Python Tiles
- 388 Distribute
- 111 Domo Everywhere
- 271 Scheduled Reports
- 6 Software Integrations
- 113 Manage
- 110 Governance & Security
- 9 Domo University
- 30 Product Releases
- Community Forums
- 40 Getting Started
- 30 Community Member Introductions
- 98 Community Announcements
- Domo Community Gallery
- 4.8K Archive