• 多级分类的级联查询sql


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

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

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

    -- 建立分类表 
    CREATE TABLE t_category
    (
    	ID INT IDENTITY(1,1) PRIMARY KEY,
    	Name VARCHAR(40) NOT NULL,
    	ParentID INT DEFAULT(-1)
    )
    
    -- 插入一些测试数据 
    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
    

      

    主要是应用了sql2005的common table expression特性。为我们提供了方便的查询方式。在cte表中可以自应用

    参考地址:http://msdn.microsoft.com/en-us/library/ms175972(v=sql.90).aspx

  • 相关阅读:
    php操作redis cluster集群成功实例
    js算法-快速排序(Quicksort)
    如何编写自己的虚拟DOM
    一文带你看透kubernetes 容器编排系统
    SpringBoot AOP控制Redis自动缓存和更新
    机器学习中的numpy库
    时间戳转自定义日期格式和刚刚、十分钟前等友好日期格式
    Python数据处理实例
    Spark1.x和2.x如何读取和写入csv文件
    掌握这个Python小技巧,轻松构建cytoscape导入文件
  • 原文地址:https://www.cnblogs.com/lyroge/p/2780920.html
Copyright © 2020-2023  润新知