首页
学习
活动
专区
工具
TVP
发布
您找到你想要的搜索结果了吗?
是的
没有找到

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

反过来呢,一个下级分类能够属于几个上级分类呢?这个并不确定,得看具体的业务需求。如果是多个实现上会更加复杂,为了讨论层级设计,这里先限定每个分类仅有一个上级分类。...其实这个方案也是一开始就能想到的,在层级不深的情况下,这个方案不失为一个好的选择。 方案二:添加路径列表 针对方案一的短板,我们表中不仅仅记录父分类id,还将它到顶级分类所有分类的id都保存下来。...就是字段长度是有限的,但 longtext 最大能存储 4G 的文本,我想没有这么变态的层级数。所以这个分类在许多系统中使用。...方案三:基于ClosureTable的无限分类存储 另建一张表存储节点之间的关系,其中包含了任何两个有关系的节点的关联信息: ?...总结 ClosureTable是一种比较完美的解决方案,对于无限分层有很好的适应性,比较适用于大型系统。

3.6K30

PHP无限分类函数封装与应用

下面的讲解我用的是ThinkPHP框架,与PHP用法是一样的。...ASC,id ASC        //这里的排序是至关重要的 Step 3、查询出的结果是一个常规的二维数组,如下图: ps:pid就是parent_id,这里是举个例子,下文一样 Step 4、封装的无限分类数组处理函数...: /**      * 无限分类      *      * @access public      * @param Array $data      *            //数据库里获取的结果集...     */      // 存放无限分类结果如果一页面有多个无限分类可以使用 Tool::$treeList = array(); 清空     public static $treeList =...,这个函数是我从互联网上看到借鉴的,进行了一些修改,希望能够帮助大家解决工作或者学习中遇到的困难,不管是PHP还是thinkphp,用法其实一样,如果此文存在错或者有不懂的地方,可以在下方评论栏留言,我将为您解答

1.6K130

PHP实现无限分类生成分类树的方法

本文实例讲述了PHP实现无限分类生成分类树的方法。...分享给大家供大家参考,具体如下: 现在的分类数据库设计基本都是:每一个分类有一个id主键字段,一个pid指向父类的id,这样便可实现无限分类,取出的数据就是如下的格式: $arr = array( array..."pid" => 2 , 'cat' => '栏目十三'), array("id" => 14, "pid" => 13 , 'cat' => '栏目十四') ); 不多说,直接上处理代码: //生成无限分类树...v){ $refer[$v['id']] = & $arr[$k]; //创建主键的数组引用 } foreach($arr as $k => $v){ $pid = $v['pid']; //获取当前分类的父级...Array ( [id] => 12 [pid] => 11 [cat] => 栏目十二 ) ) ) ) ) ) 如果大家需要这样的组装格式,或者需要该格式方便后续的处理,可以尝试此方法 希望本文所述对大家PHP

94130

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

经常在各大论坛或新闻板块详情页面下边看到评论功能,当然不单单是直接发表评论内容那么简单,可以对别人的评论进行回复,别人又可以对你的回复再次评论或回复,如此反复,理论上可以说是没有休止,从技术角度分析很容易想到运用无限分类技术存储数据...,运用递归获取评论层级结构数据,运用ajax实现评论页面交互,这里用thinkphp框架做个简单的demo练练手,为了简化流程这里第三级评论开始停止回复,当然只要在这个基础上稍作修改就可以实现无限回复功能...2.对发表的评论可以回复,回复显示在上级评论下边,形成层级关系,如下效果图 ?...<html lang="en" <head <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" <title php...无限分类实战————评论及回复功能</title <link rel="stylesheet" type="text/css" href="/Public/css/comment.css" rel=

2K30

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

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

97021

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

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

2.1K20

laravel生成无限分类

无限分类是很常见的功能,算法的好坏对于获取分类树的性能起到决定性的作用。...尤其当分类数据和层级多时,一个糟糕的算法将使服务器不堪重负 以下用laravel实现无限分类功能,包括: 数据表设计 填充模拟数据 生成分类分类树的后台维护 数据表设计 字段名 描述 id 主键id...name 类目名称 parent_id 父类目 ID is_directory 是否拥有子类目 level 当前类目层级 path 该类目所有父类目 id 为什么要用level与path 无限分类中...,我们经常需要获取一个分类的所有祖先类目或者后代类目,以及判断两个类目是否存在层级关系。...'; } else { echo '并无层级关系'; } 创建数据表 $ php artisan make:model Models/Category -m 编写迁移文件:database/migrations

2.7K40
领券