sql 多级分类的级联查询

php中文网
发布: 2016-06-07 17:49:18
原创
3755人浏览过

分类是在一般系统最常见的信息组织方式,有单级的分类,二级的分类,还有无限制级的分类。

当然我们给博客贴上分类的时候只要join下就可以找到分类的名称。

但是我们在做导航或者选择分类的时候往往涉及到分类的级联查询。下面就是说如何用sql查询这样的分类信息。

7 -- 建立分类表 

 代码如下 复制代码

CREATE TABLE t_category
(
    ID INT IDENTITY(1,1) PRIMARY KEY,
    Name VARCHAR(40) NOT NULL,
    ParentID INT DEFAULT(-1)
)

 

WaStar 网上花店系统
WaStar 网上花店系统

系统特点: 商品多级分类检索、搜索,支持同一商品多重分类,自由设置显示式样 自由设置会员类型,自由设置权限项目,自由分配每种会员类型和每个会员的权限 灵活的商品定价,最多12级价格自由分配给各种会员类型或会员,也可针对单会员单商品特殊定价 强大的会员管理、帐户管理、订单管理功能和一系列帐务查询统计功能 灵活的会员积分系统,自由设置每个积分事件的积分计算方法 灵活的网站内容发布、管理系统,每个栏目可

WaStar 网上花店系统 2
查看详情 WaStar 网上花店系统

?-- 插入一些测试数据 
INSERT INTO t_category(name) VALUES('计算机类')
INSERT INTO t_category(name) VALUES('吃的类')
INSERT INTO t_category(name, parentid) VALUES('linux', 1)
INSERT INTO t_category(name, parentid) VALUES('python', 1)
INSERT INTO t_category(name, parentid) VALUES('oracle', 1)
INSERT INTO t_category(name, parentid) VALUES('水果', 2)
INSERT INTO t_category(name, parentid) VALUES('主食', 2)
INSERT INTO t_category(name, parentid) VALUES('米饭', 7)
INSERT INTO t_category(name, parentid) VALUES('面食', 7)
INSERT INTO t_category(name, parentid) VALUES('django', 4)
INSERT INTO t_category(name, parentid) VALUES('tornado', 4)

  

?-- 问题一:如何检索一个分类的路线 即:父->子->子->子 获得这样一个路径
-- 查询django分类的路径 结果应该为计算机类->python->django  
 

 代码如下 复制代码
WITH ctetable(id,name,pid) as (
    SELECT ID,name, parentid FROM t_category WHERE ID = 10
    UNION ALL
    SELECT p2.id, p2.name, parentid FROM ctetable JOIN t_category p2 ON p2.id =ctetable.pid 
)
SELECT * FROM ctetable ORDER BY ID

  

?-- 输出结果 
1, '计算机类', -1
4, 'python', 1
10, 'django', 4

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号