p4bgroup/phalcon-nested-sets
Composer 安装命令:
composer require p4bgroup/phalcon-nested-sets
包简介
Phalcon Nested Set Models. Nested set models for Phalcon Framework
README 文档
README
Phalcon implementation for tree / hierarchy through nested sets implementation. It will calculate edges and depth for a category on creation, update and delete.
Moving "branches" is not supported (o sub-node with all it's sub-nodes) and won't be. This tool is meant to "react" to changes on a single record and keep the rest of the tree position in place.
prerequisites
Your DB must have parent, left, right, depth columns. Example:
CREATE TABLE `categories` ( `id` INT(11) NOT NULL AUTO_INCREMENT, `name` CHAR(50) NULL DEFAULT NULL, `parent_id` INT(11) NULL DEFAULT NULL, `_left` INT(11) NULL DEFAULT NULL, `_right` INT(11) NULL DEFAULT NULL, `_depth` INT(11) NULL DEFAULT NULL, PRIMARY KEY (`id`) );
usage
class MyModel extends \Phalcon\Mvc\Model { public function initialize() { $this->addBehaviour(new \P4BGroup\NestedSets\Behaviour()); } }
references
- https://en.wikipedia.org/wiki/Nested_set_model
- https://explainextended.com/2009/09/29/adjacency-list-vs-nested-sets-mysql/
- https://medium.com/@Sumurai8/nested-sets-performant-attribute-calculation-on-collections-10289a30c0ab
usage
this behaviour will automatically calculate the edges and depth of each node on save / delete
Similar implementations on other frameworks
- https://github.com/etrepat/baum - laravel
- https://github.com/lazychaser/laravel-nestedset - laravel
- https://github.com/blt04/doctrine2-nestedset - doctrine
- https://github.com/bartko-s/stefano-tree - zend / pdo
- https://github.com/creocoder/yii2-nested-sets - yii
统计信息
- 总下载量: 1.14k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 2
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2019-11-24