分类是在一般系统最常见的信息组织方式,有单级的分类,二级的分类,还有无限制级的分类。
当然我们给博客贴上分类的时候只要join下就可以找到分类的名称。
但是我们在做导航或者选择分类的时候往往涉及到分类的级联查询。下面就是说如何用sql查询这样的分类信息。
7 -- 建立分类表
代码如下 | |
CREATE TABLE t_category ?-- 插入一些测试数据 |
?-- 问题一:如何检索一个分类的路线 即:父->子->子->子 获得这样一个路径
-- 查询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
Copyright © 2019- oldu.cn 版权所有 浙ICP备2024123271号-1
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务