Last active
January 7, 2019 12:14
-
-
Save Samuyi/357c4654efbbc2e87a7f853037e7718a to your computer and use it in GitHub Desktop.
a postgreql example function for summarizing data
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
CREATE FUNCTION quarterly_summary_func(start_date date DEFAULT CURRENT_TIMESTAMP) | |
RETURNS TABLE (staff_name text, staff_bonus int, quarter tsrange) | |
As $$ | |
DECLARE | |
employee RECORD; | |
total_bonus int; | |
sales_total int; | |
end_date date := start_date + interval '3 months'; | |
BEGIN | |
FOR employee IN SELECT staff_id FROM staff LOOP | |
EXECUTE 'SELECT sum(staff_bonus), sum(sales_price) FROM sales WHERE staff_id = $1 | |
AND created_at >= $2 AND created_at < $3' | |
INTO total_bonus, sales_total | |
USING employee.staff_id, start_date, end_date; | |
RAISE NOTICE 'total bonus is % and total sales is %', total_bonus, sales_total; | |
EXECUTE 'INSERT INTO sales_summary (staff_id, bonus, total_sales, period) VALUES | |
($1, $2, $3, tsrange($4, $5))' | |
USING employee.staff_id, total_bonus, sales_total, start_date, end_date; | |
END LOOP; | |
DELETE FROM sales WHERE created_at >= start_date | |
AND created_at < end_date; | |
RETURN QUERY SELECT name, bonus, period FROM sales_summary | |
LEFT JOIN staff on sales_summary.staff_id = staff.staff_id; | |
RETURN; | |
END; | |
$$ | |
LANGUAGE plpgsql; |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment