php无限分类

name          id    parent_id   path

 新闻          1        0         0
 中国新闻      2        1         0-1
   河北新闻    3        2         0-1-2
      保定新闻                     0-1-2-3
 美国新闻      4        1         0-1
   纽约新闻    5        4         0-1-4
      华尔街新闻6       5         0-1-4-5
 俄罗斯新闻    7        1         0-1
 
字段
mysql> select * from news;
+---------+-----------+------+---------+
| news_id | news_name | pid  | path    |
+---------+-----------+------+---------+
|       1 | 新闻      |    0 | 0       |
|       2 | 中国新闻  |    1 | 0-1     |
|       3 | 美国新闻  |    1 | 0-1     |
|       4 | 河北新闻  |    2 | 0-1-2   |
|       5 | 纽约新闻  |    3 | 0-1-3   |
|       6 | 邯郸新闻  |    4 | 0-1-2-4 |
+---------+-----------+------+---------+
6 rows in set (0.00 sec)
以无线级别的思想查看数据库
mysql> select news_id,news_name,pid,path,concat(path,'-',news_id) as bpath from
news order by bpath;
+---------+-----------+------+---------+-----------+
| news_id | news_name | pid  | path    | bpath     |
+---------+-----------+------+---------+-----------+
|       1 | 新闻      |    0 | 0       | 0-1       |
|       2 | 中国新闻  |    1 | 0-1     | 0-1-2     |
|       4 | 河北新闻  |    2 | 0-1-2   | 0-1-2-4   |
|       6 | 邯郸新闻  |    4 | 0-1-2-4 | 0-1-2-4-6 |
|       3 | 美国新闻  |    1 | 0-1     | 0-1-3     |
|       5 | 纽约新闻  |    3 | 0-1-3   | 0-1-3-5   |
+---------+-----------+------+---------+-----------+
6 rows in set (0.04 sec)
News_id 自增
Pid :当前的pid是,父级news_id,
 
Path:当前的path是父级的path连上父级的news_id
bPath:当前的bpath是当前的path字段加上当前的news_id字段,他是一个临时的字段,这样就可以排序bpath,就可以达到一级一级的浏览的效果
concat()函数的参数是字符串列表,返回结果是 链接参数产生的字符串 
posted @ 2017-07-18 14:58  丶老中医  阅读(102)  评论(0编辑  收藏  举报
一切已经开始©2018 丶老中医