id列的SQL LIMIT

时间:2015-01-26 05:07:00

标签: mysql jdbc sqlyog

我有以下声明:

SELECT s.*, u.`fname`, u.`lname`, aif.`airport`
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`

让我们说,例如,这是我得到的结果:

id | ----- | ------ | ...............
 1 |  Jack |  Jones | ...............
 1 |  Moses|  Cohen | ...............
 2 |  Tom  |  Jones | ...............
 3 |  Luke | SkyWal | ...............

所以我需要使用 LIMIT 2 ,以便获得前3行(而不仅仅是前2行)。所以限制应该基于id列。它在使用 OFFSET 时也应该有用。

如何做到这一点?

1 个答案:

答案 0 :(得分:2)

不是直接读取服务表,而是使用子查询并加入到该表中。

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版本,你不能使用限制和偏移来获得子查询IN(这个版本的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`

我将假设每个服务都有一个机场在飞行中(我们可以在以后添加这种复杂性)。

要列出前两个服务,我们希望限制服务,而不是整个查询,因此它将是:

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表添加到主查询中。