SQL nome do Subcontingente de junção à esquerda

estou a correr esta pesquisa 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

e eu tenho este erro:

#1054 - Coluna desconhecida "A. post_id" em "on clause".

Acho que o meu código é muito simples, mas não o consigo corrigir. O que estou a fazer de errado?

Author: fragilewindows, 2013-05-27

2 answers

Você não selecionou post_id no subquery. Você tem que selecioná-lo no subcontingente assim:

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 
 87
Author: Mahmoud Gamal, 2013-05-27 15:22:37
Reconheço que a resposta funciona e foi aceite, mas há uma maneira muito mais limpa de escrever essa consulta. Testada em mysql e 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 
 16
Author: EJay, 2014-01-29 20:52:42