table('dept_category')." order&"/> table('dept_category')." order&">

 >  기사  >  백엔드 개발  >  何位看下这个循环嵌套数组有误吗

何位看下这个循环嵌套数组有误吗

WBOY
WBOY원래의
2016-06-13 12:02:07828검색

哪位看下这个循环嵌套数组有误吗?

function get_number_list($cat_id)<br />{<br /> $sql=$GLOBALS['db']->query("select * from ".$GLOBALS['db']->table('dept_category')." order by sort");<br /> while($row=$GLOBALS['db']->fetch_array($sql)){<br />   if($row){<br />   $result=$GLOBALS['db']->query("select * from ".$GLOBALS['db']->table('number')." where dept=".$row['cat_id']." and cat_id='$cat_id' order by sort");<br />	 while($rows=$GLOBALS['db']->fetch_array($result)){<br />	    if($rows){<br />	   $number_show[] = array(<br />	          'id' => $rows['id'],<br />			  'title' => $rows['title'],<br />			  'user' => $rows['username']<br />	   );<br />	  }<br />	 }<br />        $cat_name[]=array(<br />	      'sort' => $row['sort'],<br />	      'cat_name' => $row['cat_name'],<br />		  'topid' => $number_show<br />	 );<br />     }<br />   }<br />   return $cat_name;<br /> }

这个是源代码,这是截图:
这个是静态页面代码:
<table width="99%" align="center" cellpadding="0" cellspacing="1" bgcolor="#CCCCCC"><br />                             {foreach from=$dept_list name=dept_list item=dept}<br />							  <tr bgcolor="#FFFFFF"><br />                                <td    style="max-width:90%" colspan="2" class="bumen"> {$dept.cat_name}</td><br />                                </tr><br />							{foreach from=$dept.topid item=number}<br />                              <tr bgcolor="#FFFFFF"><br />                                <td width="46%" height="25" align="center">{$number.user}</td><br />                                <td width="54%" align="center">{$number.title}</td><br />                              </tr><br />							    {/foreach}<br />							  {/foreach}<br />                            </table>

------解决方案--------------------
因为你number_show没有清空,第一个记录获取到的一直在,所以后面就都有了。
------解决方案--------------------
function get_number_list($cat_id)<br />{<br /> $sql=$GLOBALS['db']->query("select * from ".$GLOBALS['db']->table('dept_category')." order by sort");<br /> while($row=$GLOBALS['db']->fetch_array($sql)){<br />   if($row){<br />   $result=$GLOBALS['db']->query("select * from ".$GLOBALS['db']->table('number')." where dept=".$row['cat_id']." and cat_id='$cat_id' order by sort");<br />     while($rows=$GLOBALS['db']->fetch_array($result)){<br />        if($rows){<br />       $number_show[] = array(<br />              'id' => $rows['id'],<br />              'title' => $rows['title'],<br />              'user' => $rows['username']<br />       );<br />      }<br />     }<br />        $cat_name[]=array(<br />          'sort' => $row['sort'],<br />          'cat_name' => $row['cat_name'],<br />          'topid' => $number_show<br />     );<br />    unset($number_show);<br />     }<br />   }<br />   return $cat_name;<br />   unset($cat_name);<br /> }
利用unset对数组进行清空。

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.