找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1537|回复: 0
打印 上一主题 下一主题

php 无限级分类 获取顶级分类ID

[复制链接]

2647

主题

2647

帖子

7881

积分

论坛元老

Rank: 8Rank: 8

积分
7881
跳转到指定楼层
楼主
发表于 2018-2-14 05:38:24 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            有这样一个表,id是分类的ID,name是分类名称,pid是上级分类的ID。
现在有个分类ID,程序要找到它上级的上级的上级……分类的ID,简单说就是找出顶级分类的ID。
比如“新鲜水果”的ID是13,对应父类ID是5,而5的父ID是1,1没有父类,也就是顶级分类了。
以前年轻气盛不懂事,总想着用递归来查找,然后再将结果缓存来解决性能问题。
后来又试过将整个表缓存起来,再递归查找。
再后来……似乎比较少有机会遇到无限级分类……
最近有个同事问我怎么“优雅”的解决这个问题。
于是我灵机一动,就有了如下解决方案:
pid
  1 => 0,
  // 省略...
  5 => 1,
  // 省略...
  13 => 5
];
// 建议将这数组缓存起来
$id = 13;
while($arr[$id]) {
  $id = $arr[$id];
}
echo $id; // 1
不得不说:真是太优雅了!连我都佩服我自己了,同事更是五体投地,痛哭流涕。
因为他写了几十行循环再判断再递归的代码,被我用两行代码替换了……
            
            
您可能感兴趣的文章:
  • php流量统计功能的实现代码
  • 浏览器预览PHP文件时顶部出现空白影响布局分析原因及解决办法
  • php简单的留言板与回复功能具体实现
  • php结合ajax实现赞、顶、踩功能实例
  • ThinkPHP登录功能的实现方法
  • PHP结合jQuery实现的评论顶、踩功能
  • php发送短信验证码完成注册功能
  • 判断、添加和删除WordPress置顶文章的相关PHP函数小结
  • php实现文章置顶功能的方法
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端