⑴ 如何用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;
?>
有不懂的可以问我!