搜尋
首頁後端開發php教程 发一个自己写的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>
陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
function是什么意思function是什么意思Aug 04, 2023 am 10:33 AM

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

修复:截图工具在 Windows 11 中不起作用修复:截图工具在 Windows 11 中不起作用Aug 24, 2023 am 09:48 AM

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

如何修复无法连接到iPhone上的App Store错误如何修复无法连接到iPhone上的App Store错误Jul 29, 2023 am 08:22 AM

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

php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决Jun 13, 2016 am 10:23 AM

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

"enumerate()"函数在Python中的用途是什么?"enumerate()"函数在Python中的用途是什么?Sep 01, 2023 am 11:29 AM

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

MySQL.proc表的作用和功能详解MySQL.proc表的作用和功能详解Mar 16, 2024 am 09:03 AM

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

data文件夹里面是什么数据data文件夹里面是什么数据May 05, 2023 pm 04:30 PM

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

watch4pro好还是gt好watch4pro好还是gt好Sep 26, 2023 pm 02:45 PM

watch4pro和gt各自具有不用的特点和适用场景,如果注重功能的全面性、高性能和时尚外观,同时愿意承担较高的价格,那么Watch 4 Pro可能更适合。如果对功能要求不高,更注重电池续航和价格的合理性,那么GT系列可能更适合。最终的选择应根据个人需求、预算和喜好来决定,建议在购买前仔细考虑自己的需求,并参考各种产品的评测和比较,以做出更明智的选择。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具