0

osCommerce を使用して、毎日販売された農産物の合計を表示するレポート ページを作成しています。カテゴリとサブカテゴリを表示するためにこれまでに持っているマークアップを次に示します。

<table border="0" width="100%" cellspacing="0" cellpadding="2">
<tr class="dataTableHeadingRow">
<td class="dataTableHeadingContent"><?php echo TABLE_HEADING_PRODUCTS; ?></td>
<td class="dataTableHeadingContent" align="right"><?php echo TABLE_HEADING_TOTAL_WEIGHT; ?>&nbsp;</td>
</tr>


<?php


function category_list( $category_parent_id = 0 )
{
   $sql  = 'select cd.categories_name,c.categories_id, c.parent_id, c.sort_order from ' . TABLE_CATEGORIES . ' c, ' . TABLE_CATEGORIES_DESCRIPTION . ' cd where c.categories_id = cd.categories_id AND c.parent_id='.$category_parent_id;
   $res  = tep_db_query( $sql );
   $cats = array();


    while ( $cat = tep_db_fetch_array( $res ) )
  {
    $cats[] = $cat;
  }




   if (count($cats) == 0)
    {
  return '';
  }


$list_items = array();

foreach ( $cats as $cat )
{
$list_items[] = '<tr class="dataTableRow"><td class="dataTableContent">'; 
if($category_parent_id != 0)$list_items[] = '&nbsp;&nbsp;&nbsp;';
if($category_parent_id == 0)$list_items[] = '<b>';
$list_items[] = $cat['categories_name'];


if($category_parent_id == 0)$list_items[] = '</b>';
$list_items[] = '</td><td class="dataTableContent">';
$list_items[] = category_list( $cat['categories_id'] );
$list_items[] = '</td></tr>'; 
}
$list_items[] = '';

return implode( '', $list_items );

}  

echo category_list();


?>

</table>

サブカテゴリの後に表示したいのは、それぞれの製品です。これは、TABLE_PRODUCTS_TO_CATEGORIES表を使用することを意味します。製品の数をカウントするために使用される次のコードがあります$query = 'SELECT COUNT(*) FROM '.TABLE_PRODUCTS_TO_CATEGORIES.' WHERE

これをマークアップのどこに入れ、製品をどのように表示しますか?

4

2 に答える 2

0

使用しているのと同じクエリJOINのテーブルを次のようにしないのはなぜですか。TABLE_PRODUCTS_TO_CATEGORIES

select 
  cd.categories_name,
  c.categories_id, 
  c.parent_id, 
  c.sort_order,
  p.* -- You can here select the products details you want to select.
from TABLE_CATEGORIES  c
INNER JOIN TABLE_CATEGORIES_DESCRIPTION cd ON c.categories_id = cd.categories_id 
INNER JOIN TABLE_PRODUCTS_TO_CATEGORIES p  ON p.categories_id = c.categories_id 
WHERE c.parent_id = '.$category_parent_id
于 2012-12-04T12:27:29.730 に答える
0

ここでは、製品を取得するためのアイデアです。カテゴリをチェックしている場合、CATEGORIES_ID も取得しています

後で別のクエリを作成し、同じプロセスを呼び出すだけです

于 2012-12-04T13:21:06.470 に答える