PostgreSQL
 sql >> Base de Dados >  >> RDS >> PostgreSQL

Encontre o ID do pai quando todos os filhos compartilharem o mesmo valor


Tente isso abaixo da lógica-

DEMONSTRAÇÃO AQUI
SELECT ID FROM C
WHERE ID NOT IN
(
    SELECT C.ID
    FROM C
    INNER JOIN F ON C.id = F.parent_id
    INNER JOIN oui ON F.ID = Oui.rel_id
    WHERE C.ID = CAST(oui.Product_Version AS INT)
    -- by default your column "Product Version" should be INT in table oui
)

O problema que você mencionou no comentário abaixo, você pode tentar essa conversão oposta conforme abaixo-
SELECT ID FROM C
WHERE ID NOT IN
(
    SELECT C.ID
    FROM C
    INNER JOIN F ON C.id = F.parent_id
    INNER JOIN oui ON F.ID = Oui.rel_id
    WHERE CAST(C.ID AS VARCHAR) = oui.Product_Version
)