Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Spaltenalias in WHERE-Anweisung nicht erkannt

Verwenden Sie HABEN

HAVING
  LatestBookableTimestamp < UNIX_TIMESTAMP()

Nebenbei bemerkt, Sie verwenden eine abhängige Unterabfrage, was in Bezug auf die Leistung eine schlechte Idee ist.

Versuchen Sie es folgendermaßen:

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()