Beast Mode

Beast Mode

Month Order on Bar Chart

Has anyone ever had issue with months not being in right order on X axis in bar chart? I created a custom formula just so I could Order in my card but for some reason March is showing after November on X axis. When I look at datamart all March records have a 3 so dont understand why March is out of order. Any thoughts would be greatly appreciated!

CASE WHEN MonthName = 'January' THEN '1'
WHEN MonthName = 'February' THEN '2'
WHEN MonthName = 'March' THEN '3'
WHEN MonthName = 'April' THEN '4'
WHEN MonthName = 'May' THEN '5'
WHEN MonthName = 'June' THEN '6'
WHEN MonthName = 'July' THEN '7'
WHEN MonthName = 'August' THEN '8'
WHEN MonthName = 'September' THEN '9'
WHEN MonthName = 'October' THEN '10'
WHEN MonthName = 'November' THEN '11'
WHEN MonthName = 'December' THEN '12'
ELSE '' END

Welcome!

It looks like you're new here. Members get access to exclusive content, events, rewards, and more. Sign in or register to get started.
Sign In

Best Answer

  • Coach
    Answer ✓

    You're using a string for your sorting so it goes character by character so it's going '1', '11', '12', '2'. You need to return numbers to do proper numerical sorting:

    1. CASE WHEN MonthName = 'January' THEN 1
    2. WHEN MonthName = 'February' THEN 2
    3. WHEN MonthName = 'March' THEN 3
    4. WHEN MonthName = 'April' THEN 4
    5. WHEN MonthName = 'May' THEN 5
    6. WHEN MonthName = 'June' THEN 6
    7. WHEN MonthName = 'July' THEN 7
    8. WHEN MonthName = 'August' THEN 8
    9. WHEN MonthName = 'September' THEN 9
    10. WHEN MonthName = 'October' THEN 10
    11. WHEN MonthName = 'November' THEN 11
    12. WHEN MonthName = 'December' THEN 12
    13. ELSE 99999 END

    Alternatively, if you have a date and not just the month name you can do something like:

    1. MONTH(`Date`)
    **Was this post helpful? Click Agree or Like below**
    **Did this solve your problem? Accept it as a solution!**

Answers

  • Coach
    Answer ✓

    You're using a string for your sorting so it goes character by character so it's going '1', '11', '12', '2'. You need to return numbers to do proper numerical sorting:

    1. CASE WHEN MonthName = 'January' THEN 1
    2. WHEN MonthName = 'February' THEN 2
    3. WHEN MonthName = 'March' THEN 3
    4. WHEN MonthName = 'April' THEN 4
    5. WHEN MonthName = 'May' THEN 5
    6. WHEN MonthName = 'June' THEN 6
    7. WHEN MonthName = 'July' THEN 7
    8. WHEN MonthName = 'August' THEN 8
    9. WHEN MonthName = 'September' THEN 9
    10. WHEN MonthName = 'October' THEN 10
    11. WHEN MonthName = 'November' THEN 11
    12. WHEN MonthName = 'December' THEN 12
    13. ELSE 99999 END

    Alternatively, if you have a date and not just the month name you can do something like:

    1. MONTH(`Date`)
    **Was this post helpful? Click Agree or Like below**
    **Did this solve your problem? Accept it as a solution!**
  • @AFrancis0219 Since you have single quotes around your numbers, they are actually being read as text and being sorted alphabetically. If you remove the single quotes and the ELSE, then they will be read as numbers instead

  • That worked. Thanks!

Welcome!

It looks like you're new here. Members get access to exclusive content, events, rewards, and more. Sign in or register to get started.
Sign In