我有以下声明:
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时也应该有用.
如何才能做到这一点?
解决方法:
而不是直接读取服务表,使用子查询并加入到该查询.
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表添加到主查询.
标签:mysql,jdbc,sqlyog 来源: https://codeday.me/bug/20190703/1361641.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。