Thread: select only 1 pair
select id1, id2 from table where id1<id2;
Mit freundlichen Grüßen
Martin Stöcker
-----------------------------------------
ETL Datenservice GmbH
Widdersdorfer Str. 415 | D-50933 Köln
Telefon: +49(0)2219544010
Fax: +49(0)2219544015
Email: Martin.Stoecker@etl-datenservice.de
ETL Datenservice GmbH
Widdersdorfer Str. 415 · 50933 Köln
Geschäftsführer: Dr. Dirk Goldner, Dennis Küpper, ppa. Melanie Lillich
Amtsgericht Köln · HRB 75439 · USt.-Id: DE 122 805 685
www.etl-datenservice.de
Email: info@etl-datenservice.de
Von: Shaozhong SHI <shishaozhong@gmail.com>
Gesendet: Montag, 24. Oktober 2022 16:44
An: pgsql-sql <pgsql-sql@lists.postgresql.org>
Betreff: select only 1 pair
There are pair ids. Each pair is repeated.
id1 id2
1 2
2 1
3 4
4 3
How to only select 1 unique pair for each?
Regards,
David
Attachment
select id1,id2 from your_table where id2>=id1
union
select id2,id1 from your_table where id2<id1;
should work
From: Shaozhong SHI <shishaozhong@gmail.com>
Sent: Monday, October 24, 2022 4:44 PM
To: pgsql-sql <pgsql-sql@lists.postgresql.org>
Subject: select only 1 pair
There are pair ids. Each pair is repeated. id1 id2 1 2 2 1 3 4 4 3 How to only select 1 unique pair for each? Regards, David
ZjQcmQRYFpfptBannerStart
|
ZjQcmQRYFpfptBannerEnd
There are pair ids. Each pair is repeated.
id1 id2
1 2
2 1
3 4
4 3
How to only select 1 unique pair for each?
Regards,
David
Moody's monitors email communications through its networks for regulatory compliance purposes and to protect its customers, employees and business and where allowed to do so by applicable law. The information contained in this e-mail message, and any attachment thereto, is confidential and may not be disclosed without our express permission. If you are not the intended recipient or an employee or agent responsible for delivering this message to the intended recipient, you are hereby notified that you have received this message in error and that any review, dissemination, distribution or copying of this message, or any attachment thereto, in whole or in part, is strictly prohibited. If you have received this message in error, please immediately notify us by telephone, fax or e-mail and delete the message and all of its attachments. Every effort is made to keep our network free from viruses. You should, however, review this e-mail message, as well as any attachment thereto, for viruses. We take no responsibility and have no liability for any computer virus which may be transferred via this e-mail message.
Try this.
This is an exemple of your table.
SELECT *
FROM (VALUES (1, 2), (2, 1), (3, 4), (4, 1)) t (id1, id2)
id1 |id2 |
------+------+
1| 2|
2| 1|
3| 4|
4| 1|
I think that is what you need
SELECT DISTINCT LEAST(id1, id2) AS id1, GREATEST(id1, id2) AS id2
FROM (VALUES (1, 2), (2, 1), (3, 4), (4, 3)) t (id1, id2)
id1 |id2 |
------+------+
1| 2|
3| 4|
Regards,
William Alves
There are pair ids. Each pair is repeated.id1 id21 22 13 44 3How to only select 1 unique pair for each?Regards,David
Am Mon, Oct 24, 2022 at 03:44:03PM +0100 schrieb Shaozhong SHI: > There are pair ids. Each pair is repeated. > > id1 id2 > 1 2 > 2 1 > 3 4 > 4 3 > > How to only select 1 unique pair for each? > > Regards, > David Hello, if just 2 id's then sort with min and max comparing. Example: with data (id1, id2) as ( values (1,2), (2,1), (3,4), (4,3) ) select case when id1 <= id2 then id1 else id2 end as idmin , case when not id1 <= id2 then id1 else id2 end as idmin from data group by 1, 2 ; Best regards, Frank
Shaozhong SHI schrieb am 24.10.2022 um 16:44: > There are pair ids. Each pair is repeated. > > id1 id2 > 1 2 > 2 1 > 3 4 > 4 3 > > How to only select 1 unique pair for each? select distinct least(id1,id2), greatest(id1,id2) from the_table
Hello David,
Try this.
This is an exemple of your table.
SELECT *
FROM (VALUES (1, 2), (2, 1), (3, 4), (4, 1)) t (id1, id2)
id1 |id2 |
------+------+
1| 2|
2| 1|
3| 4|
4| 1|
I think that is what you need
SELECT DISTINCT LEAST(id1, id2) AS id1, GREATEST(id1, id2) AS id2
FROM (VALUES (1, 2), (2, 1), (3, 4), (4, 3)) t (id1, id2)
id1 |id2 |
------+------+
1| 2|
3| 4|