PostgreSQL
 sql >> Base de données >  >> RDS >> PostgreSQL

Trouver l'identifiant du parent lorsque tous les enfants partagent la même valeur

Essayez ceci ci-dessous logique-

DÉMO ICI

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
)

Le problème que vous avez mentionné dans le commentaire ci-dessous, vous pouvez essayer cette conversion inverse comme ci-dessous-

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
)