首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

PHP 无限分类数据库设计及实现

♖背景 最近复习算法,在此对无限分类实现方法稍作整理,当然也是参考了道友的经验,目测适合实际的项目应用,当然,也有不少公司的笔试题还会涉及到呢,有何问题,欢迎各位道友指摘 … 操作环境:Win10...首先,实现无限分类的方式有: 以父ID设计,运用递归实现的方式 以全路径实现无限分类方式 ②....父ID 方式 核心处理代码如下,注意参数备注信息,便于正确的调用 /** * 数据库设计 递归方式 获取无限分类数据 由上到下进行获取 * @param int $pid...deepCatesForDown(0,6); $this->assign('cateListDown',$cateListDown); $this->display(); 前端Html数据显示参考: 递归方式获取 无限分类数据...全路径实现方式 对应参考上面的介绍方式,核心处理代码如下 /** * 全路径方式 获取无限分类数据 由上到下进行获取 * @return array */ public

2.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    thinkphp5实现无限分类

    首先声明一下,我们采用递归的方式来实现无限分类。但无限分类实现,不是只是递归一种方式,还有一种是全路径方式,也可以实现,不过,这种方式通常用在全路径导航菜单中。...所以,这里我们还是用最常见的递归函数来实现无限分类。...首先我们先创建一个静态方法:getCate,为什么要静态方式,因为静态方法执行效率高,不需要实例化,而且,分类查询是使用非常频繁的操作,很多查询都要依赖分类查询的结果。.../** * @param int $pid: 当前分类的父id * @param array $result:引用返回值 * @param int $blank:设置分类之间的显示提示...::all(['pid'= $pid]); //2.自定义分类名称前面的提示信息 $blank += 2; //3.遍历分类表 foreach ($res as $key =

    1.1K30

    php无限分类实现评论及回复功能

    经常在各大论坛或新闻板块详情页面下边看到评论功能,当然不单单是直接发表评论内容那么简单,可以对别人的评论进行回复,别人又可以对你的回复再次评论或回复,如此反复,理论上可以说是没有休止,从技术角度分析很容易想到运用无限分类技术存储数据...,运用递归获取评论层级结构数据,运用ajax实现评论页面交互,这里用thinkphp框架做个简单的demo练练手,为了简化流程这里第三级评论开始停止回复,当然只要在这个基础上稍作修改就可以实现无限回复功能...页面操作细节:点击某个评论的回复按钮时,显示回复文本输入框,同时其他评论的回复文本输入框消失,当再次点击该回复按钮时,该文本框消失 4.在最后一级评论(这里设置是第三级)关闭回复功能 5.即时显示评论总数 二、实现思路及细节...统计评论总数 $data['num']= $num; }else{ $data["error"] = "0"; } echo json_encode($data); } 3.view层实现...html lang="en" <head <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" <title php无限分类实战

    2.1K30

    2019-07-15 数据库无限层级分类设计

    反过来呢,一个下级分类能够属于几个上级分类呢?这个并不确定,得看具体的业务需求。如果是多个实现上会更加复杂,为了讨论层级设计,这里先限定每个分类仅有一个上级分类。...20190523135518.png 表中 pid 即直属上级分类的 id,顶级分类设为 0.这种方案简单易懂,仅用一个字典,没有冗余信息,存储空间占用极小,在数据库层面是一个很好的设计。...方案三:基于ClosureTable的无限分类存储 另建一张表存储节点之间的关系,其中包含了任何两个有关系的节点的关联信息: ?...下面看看如何用用它来实现我们的需求。...总结 ClosureTable是一种比较完美的解决方案,对于无限分层有很好的适应性,比较适用于大型系统。

    3.7K30

    laravel生成无限分类

    无限分类是很常见的功能,算法的好坏对于获取分类树的性能起到决定性的作用。...尤其当分类数据和层级多时,一个糟糕的算法将使服务器不堪重负 以下用laravel实现无限分类功能,包括: 数据表设计 填充模拟数据 生成分类分类树的后台维护 数据表设计 字段名 描述 id 主键id...name 类目名称 parent_id 父类目 ID is_directory 是否拥有子类目 level 当前类目层级 path 该类目所有父类目 id 为什么要用level与path 无限分类中...,我们经常需要获取一个分类的所有祖先类目或者后代类目,以及判断两个类目是否存在层级关系。...数据填充结果 生成分类分类树是一个通用的功能,适合将其封装为一个服务,创建CategoryService类

    2.8K40

    PHP利用递归函数实现无限分类的方法

    各种对商品分类,商品名之类的操作应该是得心应手,那么就可以尝试下无限分类列表的制作了。 什么是无限分类?...无限分类是一种分类技巧,例如部门组织,文章分类,学科分类等常用到无限分类,将其简单理解成分类就好了。...其实我们仔细想一下,生活中的分类简直太多了,衣服可以分为男装和女装,也可以分为上衣和裤子,也可以根据年龄段分类分类无处不在,分类显得“无限”。我这里就不说无限分类的必要性了。...无限分类原理简介 无限分类看似”高大上”,实际上原理是非常简单的 。无限分类不仅仅需要代码的巧妙性,也要依托数据库设计的合理性。要满足无限分类数据库需要有两个必须的字段,id,pid。...php无限分类是经常要用到的,本人以前一直用的是已经写好的,所以没仔细去研究过,下面是一个使用递归实现的简单的php无限分类的函数;也许这不是最优的方法,但对于一般的应用也足够了。

    1K21
    领券