web-dev-qa-db-ja.com

SQL LEFT JOINサブクエリエイリアス

私はこのSQLクエリを実行しています:

SELECT wp_woocommerce_order_items.order_id As No_Commande
FROM  wp_woocommerce_order_items
LEFT JOIN 
    (
        SELECT meta_value As Prenom
        FROM wp_postmeta
        WHERE meta_key = '_shipping_first_name'
    ) AS a
ON wp_woocommerce_order_items.order_id = a.post_id
WHERE  wp_woocommerce_order_items.order_id =2198

そして、私はこのエラーを受け取ります:

#1054-「on句」の不明な列「a.post_id」。

私のコードは非常にシンプルだと思いますが、正しくすることはできません。何が間違っていますか?

62
CharleyXIV

サブクエリでpost_idを選択しませんでした。次のようにサブクエリで選択する必要があります。

SELECT wp_woocommerce_order_items.order_id As No_Commande
FROM  wp_woocommerce_order_items
LEFT JOIN 
    (
        SELECT meta_value As Prenom, post_id  -- <----- this
        FROM wp_postmeta
        WHERE meta_key = '_shipping_first_name'
    ) AS a
ON wp_woocommerce_order_items.order_id = a.post_id
WHERE  wp_woocommerce_order_items.order_id =2198 
99
Mahmoud Gamal

答えは機能し、受け入れられていることは承知していますが、そのクエリを書くためのはるかにクリーンな方法があります。 mysqlとpostgresでテスト済み。

SELECT wpoi.order_id As No_Commande
FROM  wp_woocommerce_order_items AS wpoi
LEFT JOIN wp_postmeta AS wpp ON wpoi.order_id = wpp.post_id 
                            AND wpp.meta_key = '_shipping_first_name'
WHERE  wpoi.order_id =2198 
17
EJay