0
我有多个表,我正在使用以下查询按expiry_date筛选未过期的记录。'where子句'中的未知列'expiry_date'我的sql查询
我的查询:
SELECT
MT.id,
CONCAT(MEM.name,' ',MEM.last_name) AS name,
IFNULL((SELECT MAX(MFT.membership_end_date)
FROM membership_future_transaction AS MFT
WHERE MFT.membership_transaction_id = MT.id),MM.end_date) AS expiry_date,
MEM.phone,
MEM.email,
MMST.name AS membership_name,
MMST.price,
MMST.session
FROM
membership_transaction AS MT
LEFT JOIN member_master AS MEM ON MEM.id = MT.member_id
LEFT JOIN members_membership AS MM ON MM.membership_transaction_id = MT.id
LEFT JOIN membership_master AS MMST ON MMST.id = MT.membership_id
WHERE
MT.is_casual = 'No'
AND MT.is_deleted = 'No'
AND MM.is_cancelled = 'No'
AND expiry_date >= '2016-01-01'"
但我得到了“where子句”错误,请帮我我在这里失踪未知列“EXPIRY_DATE”。
[using-column-alias-in-where-clause-of-mysql-query-produce-an-error]的副本(http://stackoverflow.com/questions/942571/using-column-alias-in -where-clause-of-mysql-query-produce-an-error) – amdixon
你在哪个表中有'expiry_date'列? – Gunaseelan
如果您使用别名,请使用别名 – Drew