PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

La colonna non esiste?

Non puoi fare riferimento a un alias di colonna nella clausola WHERE.

  SELECT u1.id,
         COUNT(DISTINCT u2.userstatus) as TEMPCOLUMN 
    FROM USERS AS u1
    JOIN friendssym ON u1.id = friendssym.user_id
    JOIN USERS as u2 ON friendssym.friend_id = u2.id      
GROUP BY u1.id
  HAVING COUNT(DISTINCT u2.userstatus) = 1

Nell'SQL tradizionale, il primo a cui puoi fare riferimento a un alias di colonna è ORDER BY clausola. Ma MySQL e SQL Server consentono l'accesso nel HAVING e GROUP BY clausole.