导航:首页 > 编程语言 > php无限分类

php无限分类

发布时间:2022-01-12 09:43:25

⑴ 如何用php实现添加无限分类类似织梦后台那种可以无限添加分类

数据库设置3个字段 id name fid fid就是顶级id的意思

id name fid
1 分类1 0
2 分类2 0
3 分类1-1 1
4 分类1-2 1
5 分类2-1 2
6 分类2-2 2

数据库就是这种模式,fid为0的是最大分类。id为3 和 4的分类 是id 为 1 分类的子分类 ,所以fid都为 1 。5和6 是id 为 2的子分类。

你查找数据库的时候查找 fid=0的数据 ,找出顶级分类 1 和 2 ,再查找fid分别为 1 和 2的分类,就是对应的子类,你用foreach遍历出来就是了,

⑵ PHP+MySQL无限分类语句

无限级别的,使用递归编程比较容易,基本方法是定义一个显示子菜单的函数:

function ShowMenu($pid){

....显示数据库里面PID为$pid的所有菜单项目以及子项目(通过调用自身实现).....

}

主程序调用ShowMenu(0)实现输出整个菜单。

整个程序的逻辑一般这样:

echoShowMenu(0);

functionShowMenu($pid){
//如果数据库不存在PID=$pid的记录,返回空串""
$sql="selectcount(*)fromtabwherepid=$pid";
mysql_query($sql);
list($cnt)=mysql_fetch_row($res);
mysql_free_result($res);
if($cnt==0)return'';
//否则返回所有的子菜单项,格式<UL><LI>...<LI>...</UL>
$ret_str='<UL>';
$sql="selectid,titlefromtabwherepid=$pid";
mysql_query($sql);
while(list($id,$title)=mysql_fetch_row($res)){
$ret_str.="<LI>$title".ShowMenu($id)."</LI>";
}
mysql_free_result($res);
$ret_str.='<UL>';
return$ret_str;
}

⑶ php无限级分类

同一个表中存放父类和子类,但每一条记录都要有parent_id和category_id,最顶级分类的父id为0,然后第二层分类的父id只要是相应父类的分类id,以此类推。
显示的时候,先排序,按id就能分出来。

⑷ php递归无限分类缩进怎么做 急啊

<?php
folder();

// 主要是 $tab 参数,该参数为当前分类缩进层次
function folder($parentid = 0, $tab = 0) {
$sql = "SELECT * FROM choin_article_sort WHERE parentid = '{$parentid}' ORDER BY id DESC";
$query = mysql_query($sql);
while ($rs = mysql_fetch_array($query)) {
// 输出推荐使用 echo 命令
echo str_repeat('-', $tab); // 缩进填充符你可以自己设定,也可以是图片等等
echo '中间循环出的内容';
folder($rs["id"], $tab + 1);
}
}
?>

⑸ 如何使用PHP实现无限级分类

你还在用浪费时间又浪费内存的递归遍历无限极分类吗,看了该篇文章,我觉得你应该换换了。
这是我在OSChina上看到的一段非常精简的PHP无限极分类生成树方法,巧在引用,整理分享了。

复制代码代码如下:

function generateTree($items){
$tree = array();
foreach($items as $item){
if(isset($items[$item['pid']])){
$items[$item['pid']]['son'][] = &$items[$item['id']];
}else{
$tree[] = &$items[$item['id']];
}
}
return $tree;
}
$items = array(
1 => array('id' => 1, 'pid' => 0, 'name' => '安徽省'),
2 => array('id' => 2, 'pid' => 0, 'name' => '浙江省'),
3 => array('id' => 3, 'pid' => 1, 'name' => '合肥市'),
4 => array('id' => 4, 'pid' => 3, 'name' => '长丰县'),
5 => array('id' => 5, 'pid' => 1, 'name' => '安庆市'),
);
print_r(generateTree($items));

可以看到下面打印的结果:

复制代码代码如下:

Array
(
[0] => Array
(
[id] => 1
[pid] => 0
[name] => 安徽省
[son] => Array
(
[0] => Array
(
[id] => 3
[pid] => 1
[name] => 合肥市
[son] => Array
(
[0] => Array
(
[id] => 4
[pid] => 3
[name] => 长丰县
)

)

)

[1] => Array
(
[id] => 5
[pid] => 1
[name] => 安庆市
)

)

)

[1] => Array
(
[id] => 2
[pid] => 0
[name] => 浙江省
)

)

上面生成树方法还可以精简到5行:

复制代码代码如下:

function generateTree($items){
foreach($items as $item)
$items[$item['pid']]['son'][$item['id']] = &$items[$item['id']];
return isset($items[0]['son']) ? $items[0]['son'] : array();
}

上面这种无限极分类数据树形结构化的方法值得借鉴。但是我觉得这段代码实际用途并不明显啊,你想取出格式化的树形数据还是要递归啊:

复制代码代码如下:

/**
* 如何取数据格式化的树形数据
*/
$tree = generateTree($items);
function getTreeData($tree){
foreach($tree as $t){
echo $t['name'].'<br>';
if(isset($t['son'])){
getTreeData($t['son']);
}
}
}
getTreeData($tree);

⑹ PHP 无限级分类算法

我觉得可以用数据库查找
建临时表 列为id tab0 tab1 tab2
将数据插入后为 0 1 0 A
1 2 1 b
2 3 2 b
3 4 3 b

用sql数据查找数据就可以了
select * from table where tab0=条件 and tab1=条件 and tab2=条件即可查找所有数据

如果使用foreach遍历,效率可能要差点

⑺ 求php后台无限级分类代码,谢谢

数据库这么建就好了
id | belongid | name | img
1 | 0 | 名字A | url //A为根,0代表根级别
2 | 1 | 名字B | url //B为A的分支
3 | 1 | 名字C | url //C为A的分支
4 | 2 | 名字D | url //D为B的分支

获取get belongid,然后belongid为空或者为0的时候显示数据库belongid为0的人,点击任何一个人,进入一个子页面belongid都为被点击的这个人的id,在哪个belongid写入数据库的信息,那么,添加的这个人就belongid=GET[“belongid”],这里说的是添加
下面来讲讲提取数据,为了方便我们新加一个字段,表明当前用户在第几级,tmp字段,你也可以生成缓存表或缓存文件,先select 出 tmp=0的,然后tmp=1的,直到取到最大的一级,然后tmp=1级的belongid找0级uid的,这样子依次就可以获得所有用户树形关系了

代码的话。。
<?php
$iclass=$_GET['iclass'];
if($iclass=="")$iclass="0";
$sql="select * from movie_iclass where bid='$iclass' order by id desc";
$result=mysql_query($sql);
$num=mysql_num_rows($result);
这样,存进去就好了,应该很简单的

⑻ php如何查找会员无限分类的所有上级和所有下级

这个就要看你的数据库是怎么实现的。
我之前给一个人做个一个类似的会员推广提成的模块,就a推广出的a-1,a-2继续推广,得到a-1-1,a-1-2等等。
我的数据库设计思路如下:
用户表中有一个son这么一个字段,这个字段中存放名下所有会员的id,用分号隔开。
这个字段的维护:
比如a-1-1推广出了一个a-1-1-1,此新用户的id是12345,那么给a-1-1 a-1 a这个三个用户son字段内均添加12345这个id,删除一个用户做法一样。
有了这张表就能实现你要的效果。
查一个会员名下所有的会员,只需要读取该会员的son字段即可
查一个会员的上级 怎在数据库中所搜son字段,含有此会员id的都是他的上级会员。
当然,还有一个字段是标记此会员的直接上级会员,这样 一张表就能从任意会员得到整个会员推广树。
希望这个思路能帮到你。

⑼ php+mysql实现无限分类

..................................
不知道你要的分类是什么分类
是写一个方法实现对数据分类?
while(条件){
分类
}
条件为:如果没有此类

⑽ 急求PHP递归无限分类,当前位置写法

<?php
$testArray = array();
function getSort($num,&$testArray){
$db = new mysqli("localhost","root","123456","test");
$sql = "select * from test where bid=".$num;
$result = $db->query($sql);
if($result){
$search = array();
while($row=$result->fetch_assoc()){
$testArray[] = $row['cloumnsname'];
$search[] = $row['id'];
}
foreach($search as $key=>$value){
getSort($value,$testArray);
}
}
}
$testArray[] = "首页";
getSort(0,$testArray);
$test = implode(">",$testArray);
echo $test;
?>
有不懂的可以问我!

阅读全文

与php无限分类相关的资料

热点内容
编程之美答案 浏览:465
19月租流量热门app都有什么 浏览:632
法国电影一个女人当保姆教导自己的女儿 浏览:703
电影泳池男孩 浏览:481
下载什么app可以制作生日请柬 浏览:922
同性肉多电影 浏览:34
mac邮箱服务器地址 浏览:802
真分数化简成最简的算法 浏览:515
视易锋云服务器新加硬盘 浏览:41
加密web的数据 浏览:435
一套铠甲中间一只眼是什么电影 浏览:298
冒泡算法c语音 浏览:945
运筹算法工程师 浏览:591
国产电影推荐动作大片 浏览:618
什么app不用网络也可以玩 浏览:313
程序员必备知识 浏览:603
程序员东西没做完不让走 浏览:605
尼克电影 浏览:214
程序员的职业道德 浏览:91
图的遍历算法的原理 浏览:653