不要直接读取服务表,而是使用子查询并加入该表。
select s.*, u.`fname`, u.`lname`, aif.`airport` FROM
( select * from services order by id limit 2) as s INNER JOIN airports_in_flight aif
ON s.`id` = aif.`service_id` INNER JOIN users u
ON s.`service_provider_id` = u.`id`
根据你的 mysql 版本,你不能有一个使用限制和偏移量的子查询(这个版本的 MySQL 还不支持 'LIMIT & IN/ALL/ANY/SOME 子查询'),但这仍然有效。
编辑:
如果将内部查询设置为此:
(SELECT s.id
FROM services s
INNER JOIN airports_in_flight aif
ON s.`id` = aif.`service_id`
INNER JOIN users u
ON s.`service_provider_id` = u.`id`
LIMIT 2)
然后它只会返回带有 airports_in_flight 和 users 的服务(可能添加一个 distinct 子句)。
编辑澄清:
现在你有这个作为你的选择:
select s.*, u.`fname`, u.`lname`, aif.`airport` FROM
services as s INNER JOIN airports_in_flight aif
ON s.`id` = aif.`service_id` INNER JOIN users u
ON s.`service_provider_id` = u.`id`
您想限制为 2 项服务(我不知道您是否想要所有服务,我猜只是那些与飞行中的用户和机场匹配的服务),因此您需要将限制放在正确的表格上。
在这种情况下,右表是服务表。为了简单起见,让我们从您所拥有的简化版本开始:
SELECT s.*, aif.`airport` FROM
services as s
INNER JOIN airports_in_flight aif ON s.`id` = aif.`service_id`
我将假设每个服务的飞行排都有一个机场(我们可以稍后添加这种复杂性)。
要列出前 2 个服务,我们需要对服务进行限制,而不是整个查询,所以它是:
SELECT s.*, u.`fname`, u.`lname`, aif.`airport` FROM
(select * from services limit 2) as s
INNER JOIN airports_in_flight aif ON s.`id` = aif.`service_id`
请注意,我用查询替换了表服务,现在我可以限制,这是子查询。如果我们现在只想查看具有飞行中机场的服务,我们需要将该子查询从:
select * from services limit 2
到
select ss.* from services ss
inner join airports_in_flight aifs on ss.`in` = aifs.`service_id` limit 2
我已将服务和 airports_in_flight 表 ss 和 aifs 重命名,因此它们不会与主查询中的名称发生冲突,放入内部联接以将我的行限制为仅服务表,并限制为 2,因此将子查询放入我们现在得到的查询:
select s.*, u.`fname`, u.`lname`, aif.`airport`
FROM
(select ss.* from services ss
inner join airports_in_flight aifs on ss.`in` = aifs.`service_id`
limit 2) as s
INNER JOIN airports_in_flight aif ON s.`id` = aif.`service_id`
然后,您应该能够扩展子查询以添加用户的内部连接(从而将服务限制为仅具有 airports_in_flight 行和 users 行的服务),并将 users 表添加到主查询。