When using a date as a row in a chart, it is necessary to form groups for each date value. Otherwise, a row will be created for each date. This excess of rows will render the chart useless:
Data Field | Tag |
OrderDate | pivot1-row1-line |
data:image/s3,"s3://crabby-images/8ff15/8ff15d8cfbcc6263062feff82a7a59b344429e0a" alt="A line chart with too many date values as rows. A line chart with too many date values as rows."
The data behind the chart looks like the following:
data:image/s3,"s3://crabby-images/1d181/1d18118cc81c763921ebd4499a8898971f0a5bd8" alt="The data for a chart with too many date rows. The data for a chart with too many date rows."
Instead of listing each date as a unique value, the dates should be placed into buckets in order to provide a clearer view of the data. For example, let’s group the dates by quarter. Add the “quarter” keyword to calculate the quarter of each date.
Data Field | Tag |
OrderDate | pivot1-row1-line-quarter |
The chart is now easier to read.
data:image/s3,"s3://crabby-images/48a3c/48a3c77aa92ba082bf40fddff659e84a125c17e9" alt="A line chart showing count of orders by quarter. A line chart showing count of orders by quarter."
The data for the chart looks as follows:
data:image/s3,"s3://crabby-images/b23b5/b23b5af060faaf156b726bb2cf2fd744ae67099e" alt="Line chart showing orders by quarter. Line chart showing orders by quarter."
However, notice that we have lost information about the year. To solve this problem, we need to group the dates by year first, and then by quarter.
Data Field | Tag |
OrderDate | pivot1-row1-line-year pivot1-row2-quarter |
The chart now displays quarters per year.
data:image/s3,"s3://crabby-images/89a2f/89a2fe311176fa7fa45badac89aa8ca17b9cbe65" alt="Line chart showing orders over quarters by year. Line chart showing orders over quarters by year."
The data is shown here:
data:image/s3,"s3://crabby-images/235f3/235f31cd9ccf04e6545ed3f3c528447ea6748b29" alt="Data for chart showing orders grouped by year and quarter. Data for chart showing orders grouped by year and quarter."
However, what happens when the data is filtered to produce a different subset of data? The chart may become useless again.
data:image/s3,"s3://crabby-images/62683/626832137ec973339b6112a16f55177e3c22b549" alt="The filter has caused the chart to display only a single point. The filter has caused the chart to display only a single point."
The single row is displayed below.
data:image/s3,"s3://crabby-images/14cca/14cca0269119cb753926e77fb6a066ea644cd017" alt="Only a single row is displayed in the data. Only a single row is displayed in the data."
In order to solve this problem, an automatic grouping function can be used. By specifying a group of “date”, the server will make several attempts with various groups. The chart with a number of rows closest to 25 will be selected and displayed to the user.
Data Field | Tag |
OrderDate | pivot1-row1-line-date |
The function has decided to use year/month/week as the most optimal solution for the currently applied filter.
data:image/s3,"s3://crabby-images/e2104/e210450d976bbf57b715b6248c8bbe05f8721960" alt="The auto date grouping decided to use year/month/week. The auto date grouping decided to use year/month/week."
The data can be seen below.
data:image/s3,"s3://crabby-images/3f248/3f24871742780260d89800f2b7dc43cb199e7dbf" alt="The data for the chart. The data for the chart."
When the filter is cleared and all data from the Orders table is displayed, the group mode will try to maintain the number of rows. The function has elected on using year/month.
data:image/s3,"s3://crabby-images/24efa/24efa050cc25dbb419e59c7f9a811f3a26d2da9e" alt="All data is visible in the chart. All data is visible in the chart."
The new data can be seen here:
data:image/s3,"s3://crabby-images/a9c14/a9c14cb70d95e841d070e335ba0ac1db19a08fd7" alt="All data is visible in the table. All data is visible in the table."
A full list of available groups is displayed below.
Keyword | Description | Example Value |
date | An automatic function that will attempt several combinations of groups and select the result that has a number of rows closest to 25. | |
timeofday | Takes the hours, minutes, and second of the date. | 12:30:45 |
minute | Takes the minute from the date. | 30 |
halfhour | All dates with minutes less than 30 will be grouped into the hour group. All dates above 30 will be grouped into the half-hour group. | 1:30 |
hour | The hour will be used as the value. | 1:00 |
day | Uses the day of the month. | 31 |
dayofweek | Uses the day of the week. The value will be formatted according to the current culture. | Saturday |
dayofyear | The day of the year. | 156 |
weekofmonth | The week of the month. The value is derived from the first letter of the word “Week” in the current culture’s language, plus the number. | W3 |
week | The week of the year. | W16 |
month | The month of the year. The values will be formatted according to the current culture. | January |
quarter | The quarter in the year. The value is derived from the first letter of the word “Quarter” in the current culture’s language, plus the number. | Q1 |
year | The year. | 2015 |