sql >> データベース >  >> RDS >> PostgreSQL

2つのテーブルの行で条件が一致した場合にIDを返すクエリを作成する

    あなたの質問 この特定の質問についてのメタについて、3つの答えすべてが本当に正しい理由を説明しましょう-あなたがそれを解決した方法もそうです。

    3つの回答すべての例と、それらが取り組んでいるスキーマを含めました。

    Database changed
    mysql> create table carpet(id int(3), material varchar(10), color varchar(15));
    Query OK, 0 rows affected (0.02 sec)
    
    mysql> create table curtain(id int(3), material varchar(10), color varchar(15));
    Query OK, 0 rows affected (0.00 sec)
    

    (挿入ステートメントの束)

    mysql> select * from carpet;
    +------+-----------+--------------+
    | id   | material  | color        |
    +------+-----------+--------------+
    |    1 | wool      | Light Yellow |
    |    2 | wool      | Beige        |
    |    3 | polyester | Light Yellow |
    |    4 | polyester | Light Red    |
    +------+-----------+--------------+
    4 rows in set (0.00 sec)
    
    mysql> select * from curtain;
    +------+----------+--------------+
    | id   | material | color        |
    +------+----------+--------------+
    |    1 | Velvet   | Purple       |
    |    2 | cotton   | White        |
    |    3 | cotton   | Light Yellow |
    |    4 | cotton   | Light Blue   |
    +------+----------+--------------+
    4 rows in set (0.00 sec)
    

    交差は2つのselectステートメントを使用し、一致する結果を返します。この場合、「ライトイエロー」の色が一致するすべての行を探しています。

    MySQLはサポートされていないため、例を示すことはできません(以下に示すように、同じ結果を出す必要はありません)。

    'Light Yellow'の色のみを許可するwhere句を持つ2つのselectステートメントのユニオンクエリは、同じデータを返します。ユニオンを使用して一致しないデータを返すことはできますが、各selectステートメントのwhere句は、必要な行のみを返すことを意味します。

    mysql> select id, material, color from carpet
        -> union 
        -> select id, material, color from curtain;
    +------+-----------+--------------+
    | id   | material  | color        |
    +------+-----------+--------------+
    |    1 | wool      | Light Yellow |
    |    2 | wool      | Beige        |
    |    3 | polyester | Light Yellow |
    |    4 | polyester | Light Red    |
    |    1 | Velvet    | Purple       |
    |    2 | cotton    | White        |
    |    3 | cotton    | Light Yellow |
    |    4 | cotton    | Light Blue   |
    +------+-----------+--------------+
    8 rows in set (0.00 sec)
    

    ああ、それは悪いですよね?もちろん、where句は指定していません:

    mysql> select id, material, color from carpet where color='Light Yellow'
        -> union
        -> select id, material, color from curtain where color='Light Yellow';
    +------+-----------+--------------+
    | id   | material  | color        |
    +------+-----------+--------------+
    |    1 | wool      | Light Yellow |
    |    3 | polyester | Light Yellow |
    |    3 | cotton    | Light Yellow |
    +------+-----------+--------------+
    3 rows in set (0.00 sec)
    

    色の2つのテーブルを結合すると、両方のテーブルの行を1行のデータで返すことができます。アイテムの色について2つのテーブルの結合を指定し、where句を使用して、探している行のみを返すことができます。

    mysql> select a.id, a.material, a.color, b.id, b.material 
        -> from curtain a join carpet b on a.color=b.color;
    +------+----------+--------------+------+-----------+
    | id   | material | color        | id   | material  |
    +------+----------+--------------+------+-----------+
    |    3 | cotton   | Light Yellow |    1 | wool      |
    |    3 | cotton   | Light Yellow |    3 | polyester |
    +------+----------+--------------+------+-----------+
    2 rows in set (0.00 sec)
    

    ご覧のとおり、これにより、色が一致する行のみが返され、結果セットの1つの行に両方のテーブルの列を含めることができます。

    さて、両方のテーブルの「ライトイエロー」以外に一致する結果がないため、明らかにこれをうまく計画していませんでした。したがって、さらにいくつかのエントリを追加すると、次のようになります。

    mysql> select * from curtain;
    +------+----------+--------------+
    | id   | material | color        |
    +------+----------+--------------+
    |    1 | Velvet   | Purple       |
    |    2 | cotton   | White        |
    |    3 | cotton   | Light Yellow |
    |    4 | cotton   | Light Blue   |
    |    5 | Wool     | White        |
    |    6 | Fluff    | Beige        |
    +------+----------+--------------+
    6 rows in set (0.00 sec)
    
    mysql> select * from carpet;
    +------+-----------+--------------+
    | id   | material  | color        |
    +------+-----------+--------------+
    |    1 | wool      | Light Yellow |
    |    2 | wool      | Beige        |
    |    3 | polyester | Light Yellow |
    |    4 | polyester | Light Red    |
    |    5 | Fluff     | Light Blue   |
    +------+-----------+--------------+
    5 rows in set (0.00 sec)
    

    これで、それを再度実行できます。今回は、次のようになります。

    mysql> select a.id, a.material, a.color, b.id, b.material 
        -> from curtain a join carpet b on a.color=b.color;
    +------+----------+--------------+------+-----------+
    | id   | material | color        | id   | material  |
    +------+----------+--------------+------+-----------+
    |    3 | cotton   | Light Yellow |    1 | wool      |
    |    3 | cotton   | Light Yellow |    3 | polyester |
    |    4 | cotton   | Light Blue   |    5 | Fluff     |
    |    6 | Fluff    | Beige        |    2 | wool      |
    +------+----------+--------------+------+-----------+
    4 rows in set (0.00 sec)
    

    ああ、いや!

    ここで、join句とwhere句を一緒に使用します。

    mysql> select a.id, a.material, a.color, b.id, b.material 
        -> from curtain a join carpet b on a.color=b.color 
        -> where a.color='Light Yellow';
    +------+----------+--------------+------+-----------+
    | id   | material | color        | id   | material  |
    +------+----------+--------------+------+-----------+
    |    3 | cotton   | Light Yellow |    1 | wool      |
    |    3 | cotton   | Light Yellow |    3 | polyester |
    +------+----------+--------------+------+-----------+
    2 rows in set (0.00 sec)
    

    ご存知のとおり、SQLでは、テーブル内の同じデータのバリエーションよりも、さまざまな方法で同じ結果を得る方法が多くあります。

    編集:わかりました。すべての行のみが必要な場合 データが一致する場合は、結合構文に含めるだけです:

    mysql> select a.id, a.material, a.color, b.id, b.material 
        -> from curtain a 
        -> join carpet b on a.color=b.color
        -> and a.id=b.id
        -> where a.color='Light Yellow';
    +------+----------+--------------+------+-----------+
    | id   | material | color        | id   | material  |
    +------+----------+--------------+------+-----------+
    |    3 | cotton   | Light Yellow |    3 | polyester |
    +------+----------+--------------+------+-----------+
    1 row in set (0.00 sec)
    

    ご覧のとおり、ここで、両方のidが結合に通知します。 およびcolor フィールドは2つのテーブル間で一致する必要があり、結果はそれ自体を物語っています。さて、この場合、私は技術的にまだ 材料が異なるため、すべての列に一致しませんでした。さらに一致させたい場合、ID、マテリアル、および色が一致する一致するレコードがないため、クエリは結果を返しませんが、構文は次のようになります。

    mysql> select a.id, a.material, a.color, b.id, b.material 
        -> from curtain a 
        -> join carpet b on a.color=b.color
        -> and a.id=b.id
        -> and a.material=b.material
        -> where a.color='Light Yellow';
    Empty set (0.00 sec)
    

    ただし、ほとんどの場合、すべては必要ありません。 一致する列。多くの場合、テーブルには、そのテーブルにのみ使用され、自動的に増分される値であるIDがあります。これを使用して、内の一意の行を識別します。 テーブル。ただし、無関係のテーブルとの照合には使用しないでください。どちらかといえば、素材と色を一致させることをお勧めしますが、IDは省略してください。



    1. エイリアスMySQLv8.0としてのユーザー定義変数が機能しない

    2. MySQL IN with LIKE

    3. MySQL:SQL構文のエラー|制限0、25

    4. Webサイトのすべてのユーザーから強制的にログアウトするにはどうすればよいですか?