Một cách để thực hiện việc này là bọc truy vấn ban đầu dưới dạng truy vấn con và di chuyển WHERE
mệnh đề cho truy vấn bên ngoài:
SELECT * FROM (
SELECT `candidates`.`candidate_id`, -- this is the original query
`candidates`.`first_name`,
`candidates`.`surname`,
`candidates`.`DOB`,
`candidates`.`gender`,
DATE_FORMAT(NOW(), '%Y') - DATE_FORMAT(`candidates`.`DOB`, '%Y') - (DATE_FORMAT(NOW(), '00-%m-%d') < DATE_FORMAT(`candidates`.`DOB`, '00-%m-%d')) AS `age`
FROM `candidates` ) as innertable
WHERE `age` <= 20 -- this is now part of the outer query
làm rõ:điều này KHÔNG hoạt động trong MySQL 5
lưu ý:điều này giả định rằng truy vấn ban đầu hoạt động