How to use GROUP BY
GROUP BY is completed in Coalesce by adding your GROUP BY clause after the FROM statement, as well as after any other precursor statements like JOINs and/or a WHERE clause, in the Join tab of your Node Editor of the Node where you will complete the GROUP BY.
data:image/s3,"s3://crabby-images/1e49d/1e49d91c7d99f7dc40b37321aa0f49b20b572f54" alt="This image presents the join configuration for the same table, FCT_TOTAL_SALES_BY_STORE. The SQL snippet shows a query that selects data from the MONTHLY_SALES table, with a commented-out join to another table DIM_STORE. The query groups the results by the STORE column and filters out rows where the STORE value is null."
You will have to ensure your columns are configured correctly in your Mapping tab in terms of aggregation Transforms on column you wish to aggregate and Sources for columns you wish to GROUP BY in order for the GROUP BY to execute successfully.
data:image/s3,"s3://crabby-images/81de4/81de4aec4d4f3b997614aa458efeee7b33171057" alt="This image displays a mapping configuration for a table named FCT_TOTAL_SALES_BY_STORE. It shows columns like STORE, AMOUNT, SYSTEM_CREATE_DATE, and SYSTEM_UPDATE_DATE with their respective transformations and data types. The STORE and AMOUNT columns are sourced from the MONTHLY_SALES table, while the date columns use current timestamps."
GROUP BY Detailed Example
To provide a more detailed example, let's say you have a raw table of monthly sales amounts by store and month that you'd like to transform and load into a Fact Table of sales amounts by store in total. But rather than loading the actual store value into your Fact Table, you want to pull in the corresponding dimension key for each store from your Store Dimension, so you also need to join to your Store Dimension while completing this transform and load.
data:image/s3,"s3://crabby-images/bfef2/bfef23ec0639318b3d13bc3f11ac9af487fb8161" alt="This image demonstrates the aggregation process of sales data by store and month. On the left, there is a table listing STORE, AMOUNT, and MONTH, showing individual sales records. Below this, another table shows the DIM_STORE_KEY and STORE mapping. On the right, the result of the aggregation is displayed in a table with DIM_STORE_KEY and the total AMOUNT, showing summed amounts for each store key."
-
Add a Fact Node from your main source (
MONTHLY_SALES
). -
Remove the columns you don't want to include in your new Fact (
STORE
in its raw form andMONTH
) and configure your aggregations on your columns. -
Map in the key from your Store Dimension (
DIM_STORE
). -
Configure your join between your main source (MONTHLY_SALES) and your Store Dimension (
DIM_STORE
). -
Add a GROUP BY clause after your join on your Store Dimension key (
DIM_STORE.DIM_STORE_KEY
). -
Within the Node Editor:
- Validate Select.
- Validate Create.
- Create.
- Validate Run.
- Fetch data, and view grouped results.
data:image/s3,"s3://crabby-images/11273/11273f8c2f59c5611103c50b1777fd23a6389cf8" alt="The image displays the results of a query on the FCT_MONTHLY_SALES table, showing grouped data. The table includes columns DIM_STORE_KEY, AMOUNT, SYSTEM_CREATE_DATE, and SYSTEM_UPDATE_DATE. The results show two records with DIM_STORE_KEY values of 1 and 2, corresponding amounts of 47400 and 147500, and identical system create and update dates."