
php foreach 分开数组
比如:数据库内有idnametid1a112b213c324d415e526f61用fearch最终效果ID用户所属ID1a112b214d416f61ID用户值ID3c...
比如:数据库内有
id name tid
1 a1 1
2 b2 1
3 c3 2
4 d4 1
5 e5 2
6 f6 1
用fearch
最终效果
ID 用户 所属ID
1 a1 1
2 b2 1
4 d4 1
6 f6 1
ID 用户 值ID
3 c3 2
5 e5 2 展开
id name tid
1 a1 1
2 b2 1
3 c3 2
4 d4 1
5 e5 2
6 f6 1
用fearch
最终效果
ID 用户 所属ID
1 a1 1
2 b2 1
4 d4 1
6 f6 1
ID 用户 值ID
3 c3 2
5 e5 2 展开
3个回答
展开全部
这是一个很常见的问题.一个比较清晰简单的办法使用嵌套的循环.
外部循环输出表头:ID 用户 所属ID
内部循环就是循环你需要的4次数据.每执行完一圈内部循环就执行一次外部循环
需要注意的是,外部循环没有++这个动作,内部循环要两个++,分别是$i++和$j++
$query = mysql_query($sql);
$num = mysql_num_rows($query);
for($i=0; $i<$num;){
echo "ID 用户 所属ID\n";
for($j=0; $j<6; $j++ and $i++){
$row = mysql_fetch_assoc($query);
echo "$row[id] $row[name] $row[tid]\n";
}
}
外部循环输出表头:ID 用户 所属ID
内部循环就是循环你需要的4次数据.每执行完一圈内部循环就执行一次外部循环
需要注意的是,外部循环没有++这个动作,内部循环要两个++,分别是$i++和$j++
$query = mysql_query($sql);
$num = mysql_num_rows($query);
for($i=0; $i<$num;){
echo "ID 用户 所属ID\n";
for($j=0; $j<6; $j++ and $i++){
$row = mysql_fetch_assoc($query);
echo "$row[id] $row[name] $row[tid]\n";
}
}
参考资料: http://www.everalan.com/
展开全部
$query = mysql_query($sql);
$rows=mysql_fetch_assoc($query);
foreach($rows as $r){
$arr[$r['tid']][]=$r;//以tid为索引存放数组数据
}
echo "<pre>";
print_r($arr);
$rows=mysql_fetch_assoc($query);
foreach($rows as $r){
$arr[$r['tid']][]=$r;//以tid为索引存放数组数据
}
echo "<pre>";
print_r($arr);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
<?php
//数据库出来的数据
$array = array(
array('id'=>1,'name'=>'a1','tid'=>1),
array('id'=>2,'name'=>'b2','tid'=>1),
array('id'=>3,'name'=>'c3','tid'=>2),
array('id'=>4,'name'=>'d4','tid'=>1),
array('id'=>5,'name'=>'e5','tid'=>2),
array('id'=>6,'name'=>'f6','tid'=>1));
$tmp = array();
$tmp1 = array();
$i = 0;
foreach ($array as $v)
{
$tmp1[$v['tid']][] = $v;
}
var_dump($tmp1[1],$tmp1[2]);
?>
//数据库出来的数据
$array = array(
array('id'=>1,'name'=>'a1','tid'=>1),
array('id'=>2,'name'=>'b2','tid'=>1),
array('id'=>3,'name'=>'c3','tid'=>2),
array('id'=>4,'name'=>'d4','tid'=>1),
array('id'=>5,'name'=>'e5','tid'=>2),
array('id'=>6,'name'=>'f6','tid'=>1));
$tmp = array();
$tmp1 = array();
$i = 0;
foreach ($array as $v)
{
$tmp1[$v['tid']][] = $v;
}
var_dump($tmp1[1],$tmp1[2]);
?>
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询