カテゴリとサブカテゴリのリストを示す次のマークアップがあります。
<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; ?> </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[] = ' ';
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>
各カテゴリは太字で表示され、サブカテゴリは少し右にインデントされて表示されます。各サブカテゴリで利用可能な製品を表示する必要があります。必要な製品フィールドをSQLクエリに追加しようとしましたが、応答しませんでした。製品を検索するために追加する必要のあるフィールドは次のとおりですproducts_id, products_name
。これらはテーブルからのTABLE_PRODUCTS_DESCRIPTION
ものであり、カテゴリを並べ替えるためにTABLE_PRODUCTS_TO_CATEGORIES
、フィールドを持つ別のテーブルがありますproducts_id and categories_id
。
どうすればこれを行うことができますか?