最佳答案
我有一个问题是这样的:
SELECT
jobs.*,
(
CASE
WHEN lead_informations.state IS NOT NULL THEN lead_informations.state
ELSE 'NEW'
END
) AS lead_state
FROM
jobs
LEFT JOIN lead_informations ON
lead_informations.job_id = jobs.id
AND
lead_informations.mechanic_id = 3
WHERE
lead_state = 'NEW'
它会产生以下错误:
PGError: ERROR: column "lead_state" does not exist
LINE 1: ...s.id AND lead_informations.mechanic_id = 3 WHERE (lead_state...
在 MySql 中这是有效的,但在 Postgresql 显然不是。据我所知,原因是查询的 SELECT
部分的计算比 WHERE
部分的计算晚。对于这个问题有没有通用的解决方案?