php根据特定记录对数组中的echo记录进行分组


php echo records from array grouped by specific record

我有两个表:

房间
room_id>>room_name

1次足部按摩2面部按摩3背部按摩

订单
room_id>>>开始日期>>>>>>结束日期>>>>价格

1 2012.09.10 2012.09.11 1001 2012.09.11 2012.09.13 2002 2012.11.11 2012.11.13 1003 2012.12.11 2012.12.13 500

我想输出这样的结果:

房间号1:

2012.09.10 2012.09.11 1002012.09.11 2012.09.13 200

房间号2:

2012.11.11 2012.11.13 100

房间号3:

2012.12.11 2012.12.13 500

代码:

$query_spa = "SELECT 
rooms.room_id,
rooms.room_name,
orders.start_date,
orders.end_date,
orders.price
FROM rooms
INNER JOIN orders
ON
 rooms.room_id =orders.room_id";
 $spa = mysql_query($query_spa, $localhost) or die(mysql_error());
 $results = array();
 while($line = mysql_fetch_array($spa, MYSQL_ASSOC)){
$results[] = $line;
  }

  $groups = array();
 foreach($results as $item)
 $groups[$item['room_id']][] = $item;
  foreach($groups as $value => $items)
      echo 'room number ' . $value . ' : ' ;
for ($i=0; $i< count($items);$i++)
{
echo $items[$i]['start_date'] ;
echo $items[$i]['end_date'] ;
echo $items[$i]['price'] ;
}

输出:

房间1:房间2:房间3:2012.12.11 2012.12.13 500

试试这个:

$groups = array();
foreach($results as $item)
    $groups[$item['room_id']][] = $item;
foreach($groups as $value => $items)
{
    echo 'room number ' . $value . ' : ' ;
    foreach ($items as $item)
    {
        echo $item['start_date'] ;
        echo $item['end_date'] ;
        echo $item['price'] ;
    }
}

您可以使用简单的foreach循环浏览子项。但最好在提取步骤进行分组排序:

while($line = mysql_fetch_array($spa, MYSQL_ASSOC)){
    $groups[$line['room_id']][] = $line;
}

所以你在获取后就得到了排序结果。