sql >> Databasteknik >  >> RDS >> PostgreSQL

SQL:underfrågan har för många kolumner

Du projicerar tre kolumner i din underfråga, men jämför en enda ett av dem i IN klausul. Välj bara önskad kolumn (r1.king ) för IN i underfrågan:

SELECT kingdom.king, dinasty.birth, dinasty.death
FROM kingdom, dinasty
WHERE kingdom.king = dinasty.name AND kingdom.king NOT IN
(
    SELECT DISTINCT R1.king
    FROM
    (
        SELECT DISTINCT R1.king, D1.birth, D1.death
        FROM kingdom AS R1, dinasty AS D1, dinasty AS D2
        WHERE R1.king=D1.name
    ) AS R1, 
    (
        SELECT DISTINCT R1.king, D1.birth, D1.death
        FROM kingdom AS R1, dinasty AS D1, dinasty AS D2
        WHERE R1.king=D1.name
    ) AS R2
    WHERE R1.death-R1.birth < R2.death-R2.birth
);


  1. Definiera sammansatt nyckel med automatisk ökning i MySQL

  2. Kan den Oracle-hanterade drivrutinen använda async/wait korrekt?

  3. PostgreSQL skaffa och släpp LOCK inuti lagrad funktion

  4. Vad är det bästa sättet att automatiskt generera INSERT-satser för en SQL Server-tabell?