4

私は次の声明を持っています:

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を使用する場合にも機能するはずです。

これはどのように行うことができますか?

4

1 に答える 1

2

services テーブルを直接読み取る代わりに、サブクエリを使用してそれに結合します。

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 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)

次に、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 行を持つサービスのみに制限します)、ユーザー テーブルをメイン クエリに追加できるはずです。

于 2015-01-26T05:50:34.163 に答える