sql >> Base de Datos >  >> RDS >> Mysql

Alias ​​de columna no reconocido en declaración WHERE

Usar TENER

HAVING
  LatestBookableTimestamp < UNIX_TIMESTAMP()

En una nota al margen, está utilizando una subconsulta dependiente, lo cual es una mala idea en cuanto al rendimiento.

Prueba así:

SELECT 
  a.ID,
  a.DistanceFromUtrecht,
  pp.LatestBookableTimestamp
FROM
  Accommodation AS a
INNER JOIN (
  SELECT
    FK_Accommodation,
    MAX(DateUntil) - (ReleaseDays * 60 * 60 * 24) AS LatestBookableTimestamp
  FROM 
    PricePeriod 
  GROUP BY 
    FK_Accommodation
) AS pp    
ON pp.FK_Accommodation = a.ID    
WHERE
  pp.LatestBookableTimestamp < UNIX_TIMESTAMP()