Re: SQL question, TOP 5 and all OTHERS

From: Skylar Thompson <skylar2(at)uw(dot)edu>
To: Jean MAURICE <mauricejea(at)numericable(dot)fr>
Cc: pgsql-novice(at)lists(dot)postgresql(dot)org
Subject: Re: SQL question, TOP 5 and all OTHERS
Date: 2022-06-06 21:12:13
Message-ID: 20220606211213.dntvfnkwauk52fzc@thargelion
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-novice

On Mon, Jun 06, 2022 at 09:46:12PM +0200, Jean MAURICE wrote:
> Hi Scott,
> what about using a Common Table Expression and the clause WITH ?
> I am not at home now but you can write something like
>
> WITH top5 AS (SELECT vendor_name AS vendor_name,
>
> ?????? count(DISTINCT inv_id) AS "# of Invoices"
>
> FROM SpendTable
>
> GROUP BY vendor_name
>
> ORDER BY "# of Invoices" DESC
>
> LIMIT 5)
> SELECT * FROM top5
> UNION
>
> SELECT 'all other' AS vendor_name,
>
> ?????? count(DISTINCT st.inv_id) AS "# of Invoices"
>
> FROM SpendTable AS st
>
> WHERE st.vendor_name NOT IN (SELECT vendor_name FROM top5)
>
> ORDER BY "# of Invoices" DESC

There might be a challenge with ties, especially if you don't order by the
vendor name since you could get different results even on the same data
set, depending on how the query plan goes. It depends on what the OP is
looking for, I guess.

--
-- Skylar Thompson (skylar2(at)u(dot)washington(dot)edu)
-- Genome Sciences Department (UW Medicine), System Administrator
-- Foege Building S046, (206)-685-7354
-- Pronouns: He/Him/His

In response to

Browse pgsql-novice by date

  From Date Subject
Next Message mahendrakar s 2022-06-09 16:39:11 Need help with moving test cases in extension folder
Previous Message Jean MAURICE 2022-06-06 19:46:12 Re: SQL question, TOP 5 and all OTHERS