mysql - SQL LIMIT 按 id 列

标签 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 行)。所以 Limit 应该基于 id 列。它也应该在使用 OFFSET 时起作用。

如何做到这一点?

最佳答案

不是直接读取服务表,而是使用子查询并连接到它。

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 的服务(可能添加一个不同的子句)。

编辑澄清:

现在你有这个作为你的选择:

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 行和用户行的服务),并将用户表添加到主查询。

关于mysql - SQL LIMIT 按 id 列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28145064/

相关文章:

php - 在mysql codeigniter中的一个查询中插入和更新

mysql - 当我的左连接声明时,有人可以帮助我吗?我认为 mySQL 引擎已损坏

mysql - 如何在MySQL中对每个连续的数字系列进行查询和分组?

mysql:使用一个字段包含多个 "fields"来保存字段

php - 帮助加入和分组

java - 如何在执行查询之前获取 SQL 中的列数?即 ResultSetMetaData 以外的方式

java - 哪个更快? Statement 或 PreparedStatement

mysql - 在MySQL中将字符串转换为时间戳格式

php - 配置后 PDOException “could not find driver”

在 Windows 7 上使用 Openoffice BASE 与 Informix 进行 JDBC/ODBC 连接。不会显示表列表