SQL 按 id 列限制
SQL LIMIT by id column
我有以下声明:
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.
时也应该有效
如何做到这一点?
不要直接读取服务 table,而是使用子查询并连接到它。
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 版本,您不能使用 limit 和 offset 进行子查询 IN(此版本的 MySQL 尚不支持 'LIMIT & IN/ALL/ANY/SOME subquery'),但这仍然有效。
编辑:
如果将内部查询设置为:
(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)
然后它将只return服务于airports_in_flight和用户(可能添加不同的子句)。
编辑澄清:
现在你有这个作为你的 select:
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 项服务(我不知道你是否想要所有服务,我猜只是那些具有匹配用户和航班机场的服务),所以你需要把限制放在右边table.
在这种情况下,权利 table 是服务 table。为了简单起见,让我们从您所拥有的简化版本开始:
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`
注意我用查询替换了 table 服务,我现在可以限制它,这是子查询。如果我们现在只想查看有机场的服务,我们需要将该子查询从:
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 tables ss 和 aifs 这样它们就不会与主查询中的名称冲突,加入一个内部连接来限制我的行仅服务 table,并且限制为 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 行和用户行的服务),并添加用户 table到主查询。
我有以下声明:
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.
时也应该有效如何做到这一点?
不要直接读取服务 table,而是使用子查询并连接到它。
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 版本,您不能使用 limit 和 offset 进行子查询 IN(此版本的 MySQL 尚不支持 'LIMIT & IN/ALL/ANY/SOME subquery'),但这仍然有效。
编辑:
如果将内部查询设置为:
(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)
然后它将只return服务于airports_in_flight和用户(可能添加不同的子句)。
编辑澄清:
现在你有这个作为你的 select:
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 项服务(我不知道你是否想要所有服务,我猜只是那些具有匹配用户和航班机场的服务),所以你需要把限制放在右边table.
在这种情况下,权利 table 是服务 table。为了简单起见,让我们从您所拥有的简化版本开始:
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`
注意我用查询替换了 table 服务,我现在可以限制它,这是子查询。如果我们现在只想查看有机场的服务,我们需要将该子查询从:
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 tables ss 和 aifs 这样它们就不会与主查询中的名称冲突,加入一个内部连接来限制我的行仅服务 table,并且限制为 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 行和用户行的服务),并添加用户 table到主查询。