Documentation Charts FAQs

Build a dynamic Bar chart to compare time periods

It can be helpful to create a chart that monitors a metric’s growth in comparison to something else. Rather than using static date values, you can leverage Chartio’s Relative Date Variables to create dynamic charts whose date ranges update automatically. This is an example of a Bar chart that compares visitors in the current month with the previous month:

Bar Chart

Here’s how you can do it:

  1. Create a new chart by clicking Chart from the top nav bar.

  2. Select your data source at the top-left corner of the Query. In this example, we use our Dundersign Demo Data data source, which every Chartio user has by default.

    If you don’t see Dundersign Demo Data in your data source dropdown but would like to use it, you can add it as a new data source by selecting Dundersign Demo Data at the bottom of the page.

  3. From the Ticket table, add the Id and Created Date columns to the Columns section of the Query.

    1. Leave the aggregation as Count of distinct for Id and the time bucket as Day for Created Date.
    2. Click Ticket Id in the Result Table to rename the column; change the name to Previous Month for clarity.
  4. Now also add the Created Date column to the Filters section of the Query. We want to make sure to use the same date column for bucketing and filtering our metric.

    1. For the filter operator, use between and including
    2. For the starting date of your filter range, use {CURRENT_MONTH.START.SUB(1, 'month')}.

      This Relative Date Variable sets the current date of the filter to the first day of the previous month. To explain the code a bit more, it starts with the current month, goes to the first day of the current month, then subtracts one month—giving the first day of the previous month!

    3. For the ending date of your filter range, use {CURRENT_MONTH.END.SUB(1, 'month')}.

      This is similar to how we got the starting date, but instead looks at the last day of the month.

      Use columns from the Visitors table to create the first Query

    4. Click Run Query.

    Note: You can transform the output data of your query by adding a few steps in the Pipeline. For instance, you can add a Zero Fill step to the Pipeline. In our example, this shouldn’t change anything, but it’s good to have this step in case you have any gaps in your data.

  5. Use Apply Formula to get a Running Total of the Previous Month column. Click Save. Your “Previous Month” column now reflects the previous month’s running total.

  6. In order to compare the count on the first day of the previous month to the first day of the current month, we need to add another column. Add a Formula Column and select Custom formula. Then use the following formula to calculate the difference between the first day of the previous month and whatever date is in each row of the “Created Date” column:

    datediff({CURRENT_MONTH.START.SUB(1,'month')}, "Day of Created Date")
    

    For clarity, let’s also rename this column to Day #.

  7. Hide the Day of Created Date column. Since we’ll compare using the “Day #” column, we don’t need the “Day of Created Date” column anymore.

    Tip! You can combine Steps 6 and 7 by instead using an Apply Formula Action on the “Day of Created Date” column and use the same Custom formula provided in Step 6. Then just rename “Day of Created Date” to “Day #”.

  8. Use the Reorder Columns or Move to Start Action to move Day # to the far left of the Result Table.

  9. Now you need to bring in data for the current month. Click Add Query > Copy of Query 1 to quickly make a clone of the first Query. You need to apply the same transformations (Steps 2 - 8) to the second Query (with a few adjustments) to properly merge the two queries, which we can do before we merge them:

    1. For Copy of Query 1, edit the starting and ending dates for the Created Date filter to {CURRENT_MONTH.START} and {CURRENT_MONTH.END}, respectively.

    2. Click Run Query.
    3. Click Previous Month in the Result Table to rename the column; change the name to Current Month for clarity.
    4. Click Run Query again.

      Modify the filter and Previous Month column name in Copy of Query 1

    5. Use Apply Formula to get the running total for the “Current Month” column.
    6. Add a Formula Column, select Custom formula, then use the following formula:

      datediff({CURRENT_MONTH.START}, "Day of Created Date")
      

      Rename this new column to Day #.

    7. Hide the Day of Created Date column.
    8. Move the Day # to the far left of the Result Table.

    List of Actions applied to Copy of Query 1

  10. Click the Join Action that’s been added to your Pipeline to view the post-merge result set. By default, the two result sets are merged with an Outer Join, which is what we want for this example.

  11. Select the Bar chart type and update the Bar chart settings by clicking the Gear above the Chart Preview. Deselect Unstacked from the General tab to have separate bars for the previous and current month’s data. Feel free to change the other settings too!


  1. Create a new chart by clicking Chart from the top nav bar.
  2. Select your data source at the top-left corner of the Dataset. In this example, we use our Dundersign Demo Data data source, which every Chartio user can access.

    If you don’t see the Dundersign Demo Data in your data source dropdown but would like to use it, you can add it as a new data source by selecting Dundersign Demo Data at the bottom of the page.

    Selecting data source

  3. From the Ticket table, drag the Id column to the Measures field and the Created Date column to the Dimensions field.

    1. Leave the aggregation as Count of distinct for Id and the time bucket as Day for Created Date.

      Use default aggregation and time bucket - Count of distinct Id and Day of Created Date

    2. Click the Id column in the Measures field and change the column label for Id to Previous Month for clarity. Click Ok.

      Rename Count of dinstinct Id to Previous Month

  4. Now also add the Created Date column to the Filters field of the Query. We want to make sure to use the same date column for bucketing and filtering our metric.

    1. For the filter operator, use between and including
    2. For the starting date of your filter range, use {CURRENT_MONTH.START.SUB(1, 'month')}.

      This Relative Date Variable sets the current date of the filter to the first day of the previous month. To explain the code a bit more, it starts with the current month, goes to the first day of the current month, then subtracts one month—giving the first day of the previous month!

    3. For the ending date of your filter range, use {CURRENT_MONTH.END.SUB(1, 'month')}.

      This is similar to how we got the starting date, but instead looks at the last day of the month.

    4. Click Ok to save the filter changes.

    Use columns from the Visitors table to create the first dataset

    Note: You can transform the output data of your query by adding a few steps in the Pipeline. For instance, you can add a Zero Fill step to the Pipeline. In our example, this shouldn’t change anything, but it’s good to have this step in case you have any gaps in your data.

  5. Click Run Query.
  6. Click + Add Tranformation and add an Edit Column step to the Pipeline. For Column, select the Id column, which should now be named Previous Month. For Formula Type, select Running total. Click Apply & Close.

    The numbers in the chart table now reflect a running total.

    Calculate Running Total for Previous Month

  7. In order to compare the previous month’s data to the current month, add a third column that’ll be used for merging later on.

    1. Add an Add Column step.
    2. Give this new column the name Day #.
    3. Select Custom Formula as the Formula Type.
    4. Use the following formula: datediff({CURRENT_MONTH.START.SUB(1,'month')}. This calculates the difference between the first day of the previous month and whatever date is in each row of the “Day of Created Date” column.
    5. Click Apply & Close.

    Use datediff function to get Day #

  8. Add a Hide Columns step to hide the “Day of Created Date” column then click Apply & Close. Since we’ll compare our data using the “Day #” column, we won’t need “Day of Created Date” anymore.

    Hide Day of Created Date

  9. Use a Reorder Columns step to make the “Day #” column the leftmost column in your result set.

    Reorder columns

  10. Now you need to bring in data for the current month. Click the arrow to the left of Dataset 1 and select Clone. This will create a copy of Dataset 1 and all Pipeline steps applied to it. Very convenient!

    Clone dataset

  11. Edit Dataset 1 Clone so it brings in the current month’s data.

    1. Click Previous Month in the Measures field and rename it to Current Month. Click Ok.
    2. Click the Created Date column in the Filters field and remove .SUB(1, 'month') from both the start and end dates. The start and end dates should now be {CURRENT_MONTH.START} and CURRENT_MONTH.END, respectively. Click Ok.

    Edit Dataset 1 Clone to pull current month data

  12. Click Run Query. You’ll initially get an error, so do the following to fix it:

    1. Click the Edit Column step in the clone’s Pipeline and change the column to Current Month. Click Apply & Close.
    2. Click the Add Column step in the clone’s Pipeline and remove .SUB(1, 'month') from the Formula. It should now be datediff({CURRENT_MONTH.START}, "Day of Created Date"). Click Apply & Close.
  13. Select the Bar chart type and update the Bar chart settings by clicking Settings above the chart. Deselect Unstacked from the General tab to have separate bars for the previous and current month’s data. Feel free to change the other settings too!