我创建了一个如下数组:
$this->db->order_by('mnth','desc');
$this->db->select("users.name,users.address,awards.*");
$this->db->from('users');
$this->db->join('awards', 'users.sno = awards.mem');
$res = $this->db->get();
$resbygroup = array();
foreach($res->result_array() as $row)
{
$resbygroup[$row['mnth'].",".$row['yr']][]=($row['name'] . ", " . $row['address']);
}
if($res->num_rows()>0)
{
return $resbygroup;
}
else
{
return false;
}
目的是显示按月和年分组的获奖者名单。 在视图中,将var_dump放在返回结果上时,将得到以下输出:
array(3) { ["9,2018"]=> array(5) { [0]=> string(6) "name1, addr1" [1]=> string(31) "name2, addr2" [2]=> string(30) "name3, addr3" [3]=> string(37) "name4, addr4" [4]=> string(46) "name5, addr5" } ["8,2018"]=> array(1) { [0]=> string(46) "name7, addr7" } ["6,2018"]=> array(1) { [0]=> string(24) "name8, addr8" } }
我想获取结果并将其显示为“年月”。 我尝试了以下代码:
foreach($res as $r)
{
for($x=0;$x<count($r);$x++)
{
echo"<br>";
echo $r[$x];
echo"<br>";
}
}
它完美地显示了名称和地址对,但我也想显示第mn,yr对。输出应为:
2018年9月:name1,address1 |名称2,地址2 | name3,address3等
2018年8月:姓名7,地址7 |等等
请告诉我们如何实现
答案 0 :(得分:1)
请尝试以下代码:
foreach($res as $r=>$val)
{
echo $r; // gives mnth,yr
for($x=0;$x<count($val);$x++)
{
echo $val[$x]; //gives name,address
}
}