zoukankan      html  css  js  c++  java
  • SQL查询关于相对路径、矢代、绝对路径、递归、计算列的速度对比跟优化-SOD群记录

    1秒查原本递归的查询。 适用于:上下级。多层查询

    -- Get childs by parent id
    WITH Tree
    AS
    (
        SELECT Id,ParentId FROM dbo.Node P WHERE P.Id = 21 -- parent id
        UNION ALL
        SELECT C.Id,C.ParentId FROM dbo.Node C
        INNER JOIN Tree T ON C.ParentId = T.Id
    )
    SELECT * FROM Tree
    
    -- Get parents by child id
    WITH Tree
    AS
    (
        SELECT Id,ParentId FROM dbo.Node C WHERE C.Id = 57 -- child id
        UNION ALL
        SELECT P.Id,P.ParentId FROM dbo.Node P
        INNER JOIN Tree T ON P.Id = T.ParentId
    )
    SELECT * FROM Tree

    1、相对路劲、绝对路劲 就是差不多path这样一个列专门存放地址 ==》比较多用于分类 

    2、计算列

    补充说明下 With关键字的用法 :

    在写比较复杂的sql查询语句时,涉及到一个或多个select的语句,作为另外一个select语句的查询条件的情况时,如果一下子写不出来,可以利用with关键字,生成一个临时的表,然后在基于这个临时的表进行查询,这样,就减少了select语句的嵌套,同时也降低了难度。

     存储过程中: 临时表的创建时有必要的。 尽量少用select * into #tb  

  • 相关阅读:
    各进制转换
    免root xshell连接termux
    sqlmap怎么拿shell
    SSRF漏洞
    国外安全网站、社区论坛、博客、公司、在线工具等整合收集
    渗透测试常用工具问题总结
    cdn绕过
    xss注入
    永恒之蓝(msf17010)kali复现
    文件上传漏洞和绕过
  • 原文地址:https://www.cnblogs.com/zxs-onestar/p/5884937.html
Copyright © 2011-2022 走看看