[英]joining multiple tables with left join
我有以下查詢:
$products_query =
tep_db_query("select op.orders_products_id, op.orders_id, op.products_id, ".
"op.products_model, op.products_name, op.products_quantity, ".
"p.products_id from " . TABLE_ORDERS_PRODUCTS . " op " .
" left join " . TABLE_PRODUCTS . " p " .
" on (op.products_id = p.products_id) where orders_id = '" .
(int)$cuttinglist['orders_id'] . "'");
這會將兩個具有相同ID的表連接在一起。 我如何加入第三張表:
"TABLE_ORDERS_PRODUCTS_ATTRIBUTES"
ID與:
"TABLE_ORDERS_PRODUCTS"
使用的ID為:
"orders_products_id"
為了使您的代碼更容易閱讀(因此,您不需要到處都有這么多的concat和引號,您可以執行以下查詢:
$sql='
select
op.orders_products_id,
op.orders_id, op.products_id,
op.products_model,
op.products_name,
op.products_quantity,
p.products_id
from
'.TABLE_ORDERS_PRODUCTS.' op
left join '.TABLE_PRODUCTS.' p
on op.products_id = p.products_id
left join '.TABLE_ORDERS_PRODUCTS_ATTRIBUTES.' Attrib
on op.orders_products_id=Attrib.orders_products_id
where
orders_id = "' .(int)$cuttinglist['orders_id'] . '"
';
$products_query = tep_db_query($sql);
$products_query =
tep_db_query("select op.orders_products_id, op.orders_id, op.products_id, ".
"op.products_model, op.products_name, op.products_quantity, ".
"p.products_id from " . TABLE_ORDERS_PRODUCTS . " op " .
" left join " . TABLE_PRODUCTS . " p " .
" on (op.products_id = p.products_id) "
" left join " . TABLE_ORDERS_PRODUCTS_ATTRIBUTES . " pa " .
" on (op.products_id = pa.orders_products_id) where orders_id = '" .
(int)$cuttinglist['orders_id'] . "'");
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.