function getson($parent_id = 0, $t = - 1) {
$t++;
global $temp;
$data = M('youerdbname')->where('fatherid=' . $parent_id)->select();
if (!empty($data)) {
foreach ($data as $key => $val) {
$temp[] = $data;
getson($val['id'], $t);
}
}
return $temp;
}
if ($_SESSION['uid'] != 1) {
$massage = getson($_SESSION['uid']);
}
无限递归查询分类工作理解
1.首先我们来看一下foreach循环是什么意思,如果你懂foreach就可以跳过此步了。
开始的时候我也不理解foreach循环遍历数组是什么东西,废话少说,我们进入主题。
我们先看一下,下面这个一维数组,一维数组就不用说了吧
$a = array('零','一','二','三','四','无','六','七','八','九');
//看一下三种输出,你应该明白了,foreach遍历数组应该是干什么了吧!其实也就是把数组中的值给弄出来而已,当然你也可以用echo一个一个的给输出出来,只要你有劲,foreach就简单几句话搞定。
看完foreach我们真正进入主题,看一下无限递归到底是怎样工作的。
function getsort($table,$parent_id=0,$t=-1)
{
$t++;
global $temp;
$sql = "SELECT * FROM `$table` WHERE `parent_id`=$parent_id ORDER BY `sort_id`";
$query = mysql_query($sql);
$data = array();
while ($res = mysql_fetch_assoc($query))//循环出父级分类
{
$data[] = $res;
}
if(!empty($data))
{
foreach ($data as $key => $val )
{
$val['sort_name'] = str_repeat(' ',$t*3).'|--'.$val['sort_name'];
$temp[] = $val;
getsort($table,$val['sort_id'],$t);
}
}
return $temp;
}
看上面的while循环,当while循环完成以后,告诉我$data这个二维数组里面存的是什么?当然是一个二维数组了,而且是parent_id=0的所有数据,也就是第一级分类了。如下图:
再来看看下面这一段程序
if(!empty($data))//如果$date里面不为空,即里面有数据,就会执行下面的foreach循环
{
foreach ($data as $key => $val )
{
$val['sort_name'] = str_repeat(' ',$t*3).'|--'.$val['sort_name'];
$temp[] = $val; //把变形的sort_name在注入一个数组里
getsort($table,$val['sort_id'],$t);
}
}
首先$data不为空吧,那么foreach循环就会执行了,
foreach首先取出一条数据即$data[0],注意看上图也就是sort_id=1的所有数据
把sort_id=1的这条数据里的sort_name值给变化一下,方便做出阶梯效果的分类。
把变形的sort_name在注入一个数组里。
然后调用自己getsort,关键就在这个地方,好多人刚开始不理解,我刚开始也很不理解
关键就在下面接下来做什么?看它是怎么调用自己的,注意它调用自己时,传过去的id是$val[‘sort_id’];也就是说,下一次要查询的是parent_id=1的所有数据是吧?
最绕人的地方就是下面的解释:
第4部调用自己,去查询sort_id=1的所有子分类,和上面一样的循环过程。foreach首先取出的是第一条数据,后面是不是还有4条数据没有循环。当sort_id=1下面的所有分类查询完以后,接着 取出第二条数据,也就是$data[1],注意看上图也就是sort_id=2的所有数据,接着就是重复上面的动作。
还有一种比较好的理解方法,当它调用自己时即getsort($table,$val['sort_id'],$t);把这句话替换成getsort()函数它本身,就容易理解多了。
可能我解释的还不够清楚,不知到你是否理解了。
调用一下这个函数,然后循环一下就是下图这个样子
$a = getsort('article_sort');
foreach ($a as $key => $val )
{
echo '<pre>';
echo $val['sort_name'];
}