首先,创建一个DB

CREATE TABLE IF NOT EXISTS `class` (
`id` mediumint(6) NOT NULL AUTO_INCREMENT,
`title` varchar(30) NOT NULL,
`pid` mediumint(6) NOT NULL DEFAULT '0',
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8

然后插入数据

INSERT INTO `class` VALUES (1, '品牌女装', 0);
INSERT INTO `class` VALUES (2, '精品男装', 0);
INSERT INTO `class` VALUES (3, '连衣裙', 1);
INSERT INTO `class` VALUES (4, '旗袍', 1);
INSERT INTO `class` VALUES (5, '燕尾服', 2);

数据的结构能够自己去设计

这里采用递归的方法去实现无限极栏目分类

<?php 

$con = mysql_connect("localhost","root","123456");

mysql_query("set names 'utf8'");
mysql_select_db("test"); function get_str($id = 0) {
global $str;
$sql = "select id,title from class where pid= $id";
$result = mysql_query($sql);
if($result && mysql_affected_rows()){
$str .= '<ul>';
while ($row = mysql_fetch_array($result)) {
$str .= "<li>" . $row['id'] . "--" . $row['title'] . "</li>";
get_str($row['id']);
}
$str .= '</ul>';
}
return $str;
} echo get_str(0); ?>

返回一个数组

<?php 

$con = mysql_connect("localhost","root","123456");

mysql_query("set names 'utf8'");
mysql_select_db("test"); function get_array($id=0){
$sql = "select id,title from class where pid= $id";
$result = mysql_query($sql);
$arr = array();
if($result && mysql_affected_rows()){
while($rows=mysql_fetch_assoc($result)){
$rows['list'] = get_array($rows['id']);
$arr[] = $rows;
}
return $arr;
}
}
$list = get_array(0);
var_dump($list);?>

第三种分类;将同一个字段的一样的值归为一类,

 function Staff_Pay_nen($type,$emp_cd){
$con=dbcon9();
$sql = " ";
$sql .= " SELECT ";
$sql .= " pay_nen ";
if($type == "haken"){
//派遣
$sql .= " FROM ";
$sql .= " tbl_staff_gensen ";
$sql .= " WHERE ";
$sql .= " staff_cd = '".$emp_cd."' AND ";
$sql .= " kokyaku_cd= '000000' AND ";
$sql .= " sagyo_type='0' AND ";
}elseif($type == "syoukai"){
//日々紹介
$sql .= " ,kokyaku_cd ";
$sql .= " FROM ";
$sql .= " tbl_staff_gensen ";
$sql .= " WHERE ";
$sql .= " staff_cd = '".$emp_cd."' AND ";
$sql .= " sagyo_type ='1' AND ";
$sql .= " kokyaku_cd <> '000000' AND ";
$sql .= " pay_nen is not null AND ";
}
if(1 <= date("n",time()) && date("n",time()) <=6){
//処理日前年と処理日当年
$sql .= " pay_nen in (to_char(now(),'yyyy'),to_char(now() + '-1 year','yyyy')) ";
}else if(7 <= date("n",time()) && date("n",time()) <=12){
//処理日当年のみ
$sql .= " pay_nen in (to_char(now(),'yyyy')) ";
}
$sql .= " ORDER BY ";
$sql .= " pay_nen desc ";
$sql .= " ,kokyaku_cd ASC ";
$result=pg_query($sql);
$i = 0;
$test_day = "";
$pay_nen = array();
if($type == "haken"){
//派遣
while($row=pg_fetch_assoc($result)){
$pay_nen[$i] = $row['pay_nen'];
$i++;
}
}elseif($type == "syoukai"){
//日々紹介
while($row=pg_fetch_assoc($result)){
if($test_day == $row['pay_nen']){
$pay_nen[$row['pay_nen']] .= ",".$row['kokyaku_cd'];
}else{
$pay_nen[$row['pay_nen']] = $row['kokyaku_cd'];
}
$test_day = $row['pay_nen'];
}
}
return $pay_nen;
}

这样的显示如下

品牌女装
连衣裙
旗袍
精品男装
燕尾服

PHP 实现无限极栏目分类的更多相关文章

  1. Think PHP递归重新排序无限极子分类数组(递归无限极分类)

    Think PHP递归重新排序无限极子分类数组 // 递归重新排序无限极子分类数组 function recursive($array,$pid=0,$level=0){ $arr = array() ...

  2. 夺命雷公狗ThinkPHP项目之----企业网站8之栏目的添加完善(无限极分类的完成)

    我们刚才只是完成了添加的一部分,但是我们的上级分类也不能永远都是只有一个死的嘛,所以我们需要对她进行修改: 我们先将add方法里面的数据查出来再说: 然后在模板页进行遍历: 展示效果如下所示: 虽然是 ...

  3. 谈一次php无限极分类的案例

    作者:白狼 出处:http://www.manks.top/php_tree_deep.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追 ...

  4. PHP无限极分类的几种方法

    导读:项目开发,经常栏目要做到无限极分类,几种方法PHP无限极分类的几种方法 复制代码 代码如下:namespace Util;class Category{static public functio ...

  5. php不使用递归实现无限极分类

    无限极分类常用的是递归,但是比较不好理解,其实可以用数据库path,pid两个字段的设计来实现无限分类的功能 1.数据库设计 通过上图可以看出pid就是该栏目的父id,而path = 父path+pi ...

  6. php无限极分类以及递归(thinkphp)

    php无限极分类: 无限极分类重点在于表的设计: 1在model中: class CatModel extends Model{ protected $cat = array(); public fu ...

  7. js实现无限极分类

    转载注明出处!!! 转载注明出处!!! 转载注明出处!!! 因为要实现部门通讯录,后台传来的数据是直接从数据库里拿的部门表,所以没有层级分类,只有parentId表示从属关系,所以分类的事情就交给我来 ...

  8. C#无限极分类树-创建-排序-读取 用Asp.Net Core+EF实现之方法二:加入缓存机制

    在上一篇文章中我用递归方法实现了管理菜单,在上一节我也提到要考虑用缓存,也算是学习一下.Net Core的缓存机制. 关于.Net Core的缓存,官方有三种实现: 1.In Memory Cachi ...

  9. PHP无限极分类

      当你学习php无限极分类的时候,大家都觉得一个字“难”我也觉得很难,所以,现在都还在看,因为工作要用到,所以,就必须得研究研究. 到网上一搜php无限极分类,很多,但好多都是一个,并且,写的很乱, ...

随机推荐

  1. ubuntu wubi安装注意事项

    从这个镜像下载 http://mirrors.163.com/ubuntu-releases/12.10/ ubuntu-12.10-desktop-amd64.iso 和 wubi.exe然后放到同 ...

  2. Js使用word书签填充内容

    Js使用word书签填充内容 1.在模板文件中需要填充的地方插入书签 填充内容为:(|光标所在处) 填写书签名,点击添加完成: 2.使用js打开模板,获取书签位置,填充数据: function pri ...

  3. bzoj3531

    不难想到树链剖分这题的难点是记录的是路径上宗教相同的点裸的想法是对每一种宗教都开一棵线段树,记录每个点的评级但显然这样会爆空间,仔细分析一下,这些线段树内很多点压根就没用到因此我们考虑对线段树动态开点 ...

  4. Android 开发无线调试

    在进行android开发的时候有时候总是连接不上设备,因为设备的USB进行频繁插拔之后会导致一定的损坏.所以在设备已经无法利用数据线进行连接开发工具的时候就需要有那么一个功能,那就是无线调试,是不是感 ...

  5. 【宽搜】Vijos P1206 CoVH之再破难关

    题目链接: https://vijos.org/p/1206 题目大意: 给你开始和结束两张4x4的01图,每次操作只能够交换相邻的两个格子(有公共边),问最少的操作步数. 题目思路: [搜索] 这题 ...

  6. poj3294 Life Forms(后缀数组)

    [题目链接] http://poj.org/problem?id=3294 [题意] 多个字符串求出现超过R次的最长公共子串. [思路] 二分+划分height,判定一个组中是否包含不小于R个不同字符 ...

  7. hdu 4604 Deque(最长上升与下降子序列-能够重复)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4604 这个题解有点问题,暂时没时间改,还是参考别人的吧 #include <cstdio> ...

  8. hdu 3553 Just a String (后缀数组)

    hdu 3553 Just a String (后缀数组) 题意:很简单,问一个字符串的第k大的子串是谁. 解题思路:后缀数组.先预处理一遍,把能算的都算出来.将后缀按sa排序,假如我们知道答案在那个 ...

  9. DB2 创建数据库

    0.一些准备工作可能用到的命令 db2cmd --进入db2命令行 db2 list database directory --显示已有的数据库 db2 drop db pcore --删除一个数据库 ...

  10. 【bzoj3514】Codechef MARCH14 GERALD07加强版

    hzwer上少有的几道需要建一下模的 要不是有这么几道题 我都觉得lct只会考裸题了呢 题解看hzwer吧 http://hzwer.com/4358.html 唯一蛋疼的就是为了处理0这个呵呵的位置 ...