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()函数的参数是字符串列表,返回结果是 链接参数产生的字符串