发一个自己写的PHP树类 tree for php,该如何解决
发一个自己写的PHP树类 tree for php
自己经常在做无限极分类的时候
需要传说中的数据结构之树
但是找了一下
貌似找不到合适我自己的
今天就写了一个
拿出来晒晒
需要数据库支持的无限极 树类
希望各位朋友指点、补充,
-------------开源宣言--------------
开源给我们带来的应该是减少重复性的工作
达到共同提高
- PHP code
<!-- Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ --> <?php /* PHP实现数据结构 树类 需要数据库之持 暂不支持文件和内存保存数据 版本:1.0 时间:2010年4月1日 作者:未知树工作室 www.untree.net 刘定发 数据库表结构 CREATE TABLE `tree` ( `c_id` bigint(20) unsigned NOT NULL auto_increment, `c_name` varchar(255) NOT NULL default '''none''', `c_fid` bigint(20) unsigned default '0', `c_data` varchar(255) default NULL, PRIMARY KEY (`c_id`) ) 表名称可以在类构造函数中指定 函数索引: 1、构造函数 $mode 默认为db 其他模式不支持 $name 树名称 $tb_file_name:表名称 ,文件模式使用文件名(暂时无用) $db_data为数据库参数 $db_set=array( 'db_host'=>'localhost', 'db_user'=>'root', 'db_pass'=>'123456', 'db_name'=>'sy_speedphp' ); function __construct($mode='db',$name,$tb_file_name='tree',$db_data=NULL) 2、添加结点 //插入成功返回插入ID $data为数据域 function addnode($fid=0,$data) 3、修改一个结点的信息 只能修改FID和DATA域 //如果不指定 。默认不修改 function mdfnode($node_id,$fid=false,$data=false) 4、删除结点及其子节点 id为结点ID mode为删除模式 ture为直接删除 false为将指定结点和子节点移动到一个新树中 并返回随机的新树的名称 function deletenode($id,$mode=true) 5、获取子节点函数 不包括指定的根节点 递归调用函数 function getsub($fid,$deep=8888,$storage_mode=true,$recall=NULL) $fid为根结点ID $deep:遍历深度 从1开始 1即是子节点 2是孙结点 $storage_mode=true时 使用多维数组返回父子关系 $storage_mode=false时 使用一维数组返回 不记录父子关系 $recall 回调函数 如果不为空 在遍历过程中 每个数据都将调用该函数 回调函数定义如下 function function_name($node_data,$deep); $node_data为结点数据 deep为深度,从1开始 表示该结点到所指定根结点(fid)的距离 回调函数参数传递时如下所示 function myfunction($node_data,$deep){code};//自定义函数 $tree1->getsub(0,8888,true,"myfunction")//使用函数名作为参数 当保存为多维数组的时候结构如下 array ( fid1=>array(), fid2=>array ( fid21=>array(id,name,fid,data), fid22=>array(id,name,fid,data), ) $fid3=>data; ) 其中fid1,fid2……为根节点的ID 其对应值为子节点信息 //注意:只有叶子节点才能返回具体数据 //$deep为深度 默认为-1,表示返回所有 例如deep=1时,返回第一层子节点 6、获取结点信息 返回结点信息 并为数组添加键值为 sub_count=>子节点数量 function getnode(4); 7、//获取根向上类别信息 function getfarlist($node_id,$fadeep) //@param:$fadeep 向上的等级 返回数据从最靠近的排在前面 fadeep从1开始 返回一个二维数组 8、提交查询 如果为insert update delete 只返回true or false 如果为SELEC 返回二维数组 function db_query($sql) 9、错误信息函数 可以自定义修改 目前只是显示错误信息 function erro($msg); */ //设置调试模式开关 true 为打开 输出SQL语句 define('DEBUG_MODE',false); class cls_tree { //数据存储的模式 'file'|'db'|'mem'分别为文件和数据库 //如果存为文件 需要指定文件位置 //如果存为数据库 需要创建表 并指定数据库链接相关配置信息 private $mode; private $db_host;//主机 private $db_port;//端口 默认为3306 private $db_user;//用户名 private $db_pass;//密码 private $db_name;//数据库名; private $tb_name;//树结构表名字 private $file_name;//数据文件位置 private $link_id;//数据库链接ID //private $link_tb;//和树节点相关联的表名称 用于修改的时候关联修改 private $tree_name;//树的名称 每个树必须有一个自己的名称 一个数据库表中必然存在多个树 public $debug;//设置为true 的时候为调试状态 //构造函数 //链接数据库 使用数据库表作为数据中心 /*用数据库或者数据文件名 来构造 array{ $db_host=NULL, $db_user ,$db_pass ,$db_name, $filename } */ public function __construct($mode='db',$name,$tb_file_name='tree',$db_data=NULL) { if($mode=='db')//数据库 { $this->link_id=mysql_connect( $db_data['db_host'] , $db_data['db_user'] , $db_data['db_pass']); if(!$this->link_id) { echo 'Can not connect MySQL Server'; return false; } if ( ! mysql_select_db($db_data['db_name'],$this->link_id) ) { echo 'Can not use MySQL Database'; return false; } //设置调试模式 输出SQL语句 $this->debug=DEBUG_MODE; $this->tb_name=$tb_file_name; $this->tree_name=$name; mysql_query("set names 'gb2312';",$this->link_id); }//如果使用数据库存储数据 else if($mode=='file') { $this->file_name=$tb_file_name; } else if($mode=='mem') //其他方式 内存 { } else { die('erro to construct object without storage mode'); } }//__construct //添加一个结点 //如果父节点ID为0 插入为根节点 //插入成功返回插入ID function addnode($fid=0,$data) { $data=mysql_escape_string($data);//MSYQL过滤 if($fid)//如果父节点ID不为0 { //如果父节点ID不为零 需要检查是否存在父节点 $sql='select count(*) as sum from '.$this->tb_name. ' where c_id='.$fid.' and c_name=\''.$this->tree_name.'\';'; $re=$this->db_query($sql); if($re[0]['sum']!=1) { $this->erro('not exist parent node ,parent id:'.$fid.'<br>'); return ; } //////执行插入结点 $sql='insert into '.$this->tb_name.' values(NULL,'."'{$this->tree_name}','{$fid}','$data');"; if($this->db_query($sql)) { return mysql_insert_id($this->link_id); } else { return false; } } //插入为根节点 需要查询树名称是否已经被使用 一个树只有一个根节点 执行插入结点 else { $sql='select count(*) as sum from '.$this->tb_name. ' where c_name=\''.$this->tree_name.'\';'; $re=$this->db_query($sql); if($re[0]['sum']!=0) { $this->erro('can not create tree,even existed tree name:'.$this->tree_name.'<br>'); return ; } else { $sql='insert into '.$this->tb_name.' values(NULL,'."'{$this->tree_name}','{$fid}','$data');"; if($this->db_query($sql)) { return mysql_insert_id($this->link_id); } } } } <div class="clear"> </div>

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

许多用户在选择智能手表的时候都会选择的华为的品牌,其中华为GT3pro和GT4都是非常热门的选择,不少用户都很好奇华为GT3pro和GT4有什么区别,下面就就给大家介绍一下二者。华为GT3pro和GT4有什么区别一、外观GT4:46mm和41mm,材质是玻璃表镜+不锈钢机身+高分纤维后壳。GT3pro:46.6mm和42.9mm,材质是蓝宝石玻璃表镜+钛金属机身/陶瓷机身+陶瓷后壳二、健康GT4:采用最新的华为Truseen5.5+算法,结果会更加的精准。GT3pro:多了ECG心电图和血管及安

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果,其目的是封装一段可重复使用的代码,提高代码的可重用性和可维护性。

为什么截图工具在Windows11上不起作用了解问题的根本原因有助于找到正确的解决方案。以下是截图工具可能无法正常工作的主要原因:对焦助手已打开:这可以防止截图工具打开。应用程序损坏:如果截图工具在启动时崩溃,则可能已损坏。过时的图形驱动程序:不兼容的驱动程序可能会干扰截图工具。来自其他应用程序的干扰:其他正在运行的应用程序可能与截图工具冲突。证书已过期:升级过程中的错误可能会导致此issu简单的解决方案这些适合大多数用户,不需要任何特殊的技术知识。1.更新窗口和Microsoft应用商店应用程

第1部分:初始故障排除步骤检查苹果的系统状态:在深入研究复杂的解决方案之前,让我们从基础知识开始。问题可能不在于您的设备;苹果的服务器可能会关闭。访问Apple的系统状态页面,查看AppStore是否正常工作。如果有问题,您所能做的就是等待Apple修复它。检查您的互联网连接:确保您拥有稳定的互联网连接,因为“无法连接到AppStore”问题有时可归因于连接不良。尝试在Wi-Fi和移动数据之间切换或重置网络设置(“常规”>“重置”>“重置网络设置”>设置)。更新您的iOS版本:

php提交表单通过后,弹出的对话框怎样在当前页弹出php提交表单通过后,弹出的对话框怎样在当前页弹出而不是在空白页弹出?想实现这样的效果:而不是空白页弹出:------解决方案--------------------如果你的验证用PHP在后端,那么就用Ajax;仅供参考:HTML code

MySQL.proc表的作用和功能详解MySQL是一种流行的关系型数据库管理系统,开发者在使用MySQL时常常会涉及到存储过程(StoredProcedure)的创建和管理。而MySQL.proc表则是一个非常重要的系统表,它存储了数据库中所有的存储过程的相关信息,包括存储过程的名称、定义、参数等。在本文中,我们将详细解释MySQL.proc表的作用和功能

在本文中,我们将了解enumerate()函数以及Python中“enumerate()”函数的用途。什么是enumerate()函数?Python的enumerate()函数接受数据集合作为参数并返回一个枚举对象。枚举对象以键值对的形式返回。key是每个item对应的索引,value是items。语法enumerate(iterable,start)参数iterable-传入的数据集合可以作为枚举对象返回,称为iterablestart-顾名思义,枚举对象的起始索引由start定义。如果我们忽

data文件夹里面是系统及程序的数据,比如软件的设置和安装包等,Data文件夹中各个文件夹则代表的是不同类型的数据存放文件夹,无论Data文件指的是文件名Data还是扩展名data,都是系统或程序自定义的数据文件,Data是数据保存的备份类文件,一般可以用meidaplayer、记事本或word打开。
