SQL是Structured Query Language(结构化查询语言)的缩写。SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。SQL功能强大、简单易学、使用方便,已经成为了数据库操作的基础,并且现在几乎所有的数据库均支持SQL。 这里首先介绍一下,什么是无限极分类?无限极分类简单点说就是一个类可以分成多个子类,然后一个子类又可以分另外多个子类这样无限分下去,就好象windows可以新建一个文件夹,然后在这个文件夹里又可以建一些个文件夹,在文件夹底下还可以建一些文件夹一样 那php又是如何实现它的无限分类的呢?如何把它的各个分类一一列出来呢?代码如下 <?php
/**
* 无限级分类 类
*/
class Category{
/**
* 返回一维数组
* @param [type] $cate 要递归的数组
* @param string $html 子级分类前要显示的缩进符号。默认 '─'
* @param integer $pid 父级分类ID。默认为 0,表示顶级分类
* @param integer $level level级,配合 $html 显示足够的缩进。默认为 1,表示顶级分类
* @return [type] [description]
*/
static public function unlimitedForLevel($cate, $html = '─', $pid = 0, $level = 1){
$arr = array();
foreach($cate as $v){
if($v['pid'] == $pid){
$v['level'] = $level;
$v['html'] = str_repeat($html, $level - 1);
$arr[] = $v;
$arr = array_merge($arr, $this->unlimitedForLevel($cate, $html, $v['id'], $level + 1));
}
}
return $arr;
}
/**
* 返回多维数组
* @param [type] $cate 要递归的数组
* @param string $name 子级分类在父分类数组中的 key
* @param integer $pid 父级分类ID。默认为0,表示顶级分类
* @return [type] [description]
*/
static public function unlimitedForlayer($cate, $name = 'child', $pid = 0){
$arr = array();
foreach($cate as $v){
if( $v['pid'] == $pid){
$v[$name] = self::unlimitedForlayer($cate, $name, $v['id']);
$arr[] = $v;
}
}
return $arr;
}
/**
* 传递子分类ID返回所有父级分类
* @param [type] $cate 要递归的数组
* @param [type] $id 子分类ID
* @return [type] [description]
*/
static public function getParents($cate, $id){
$arr = array();
foreach($cate as $v){
if($v['id'] == $id){
$arr[] = $v;
$arr = array_merge(self::getParents($cate, $v['pid']), $arr);
}
}
return $arr;
}
/**
* 传递父级分类ID返回所有子分类ID
* @param [type] $cate 要递归的数组
* @param [type] $pid 父级分类ID
* @return [type] [description]
*/
static public function getChildrenId($cate, $pid){
$arr = array();
foreach($cate as $v){
if($v['pid'] == $pid){
$arr[] = $v['id'];
$arr = array_merge($arr, self::getChildrenId($cate, $v['id']));
}
}
return $arr;
}
/**
* 传递父级分类ID返回所有子级分类
* @param [type] $cate 要递归的数组
* @param [type] $pid 父级分类ID
* @return [type] [description]
*/
static public function getChildren($cate, $pid){
$arr = array();
foreach($cate as $v){
if($v['pid'] == $pid){
$arr[] = $v;
$arr = array_merge($arr, self::getChildren($cate, $v['id']));
}
}
return $arr;
}
}
?> 以上就是php 无限级分类示例代码的详细内容,更多请关注php中文网其它相关文章!
学习教程快速掌握从入门到精通的SQL知识。
|