DDR爱好者之家 Design By 杰米

一、查询当前部门下的所有子部门

WITH  dept
    AS ( SELECT  *
        FROM   dbo.deptTab --部门表
        WHERE  pid = @id
        UNION ALL
        SELECT  d.*
        FROM   dbo.deptTab d
            INNER JOIN dept ON d.pid = dept.id
       )
  SELECT *
  FROM  dept

二、查询当前部门所有上级部门

WITH  tab
     AS ( SELECT  DepId ,
            ParentId ,
            DepName ,
            [Enable] ,
            0 AS [Level]
        FROM   deptTab WITH ( NOLOCK ) --表名
        WHERE  [Enable] = 1
            AND depId = @depId
        UNION ALL
        SELECT  b.DepId ,
            b.ParentId ,
            b.DepName ,
            b.[Enable] ,
            a.[Level] + 1
        FROM   tab a ,
            deptTab b WITH ( NOLOCK )
        WHERE  a.ParentId = b.depId
            AND b.[enable] = 1
       )
  SELECT *
  FROM  tab WITH ( NOLOCK )
  WHERE  [enable] = 1
  ORDER BY [level] DESC

三、查询当前表的说明描述

SELECT tbs.name 表名 ,
    ds.value 描述
FROM  sys.extended_properties ds
    LEFT JOIN sysobjects tbs ON ds.major_id = tbs.id
WHERE  ds.minor_id = 0
    AND tbs.name = 'userTab';--表名

四、查询当前表的表结构(字段名、属性、默认值、说明等)

SELECT CASE WHEN col.colorder = 1 THEN obj.name
       ELSE ''
    END AS 表名 ,
    col.colorder AS 序号 ,
    col.name AS 列名 ,
    ISNULL(ep.[value], '') AS 列说明 ,
    t.name AS 数据类型 ,
    col.length AS 长度 ,
    ISNULL(COLUMNPROPERTY(col.id, col.name, 'Scale'), 0) AS 小数位数 ,
    CASE WHEN COLUMNPROPERTY(col.id, col.name, 'IsIdentity') = 1 THEN '√'
       ELSE ''
    END AS 标识 ,
    CASE WHEN EXISTS ( SELECT  1
              FROM   dbo.sysindexes si
                  INNER JOIN dbo.sysindexkeys sik ON si.id = sik.id
                               AND si.indid = sik.indid
                  INNER JOIN dbo.syscolumns sc ON sc.id = sik.id
                               AND sc.colid = sik.colid
                  INNER JOIN dbo.sysobjects so ON so.name = si.name
                               AND so.xtype = 'PK'
              WHERE  sc.id = col.id
                  AND sc.colid = col.colid ) THEN '√'
       ELSE ''
    END AS 主键 ,
    CASE WHEN col.isnullable = 1 THEN '√'
       ELSE ''
    END AS 允许空 ,
    ISNULL(comm.text, '') AS 默认值
FROM  dbo.syscolumns col
    LEFT JOIN dbo.systypes t ON col.xtype = t.xusertype
    INNER JOIN dbo.sysobjects obj ON col.id = obj.id
                     AND obj.xtype = 'U'
                     AND obj.status >= 0
    LEFT JOIN dbo.syscomments comm ON col.cdefault = comm.id
    LEFT JOIN sys.extended_properties ep ON col.id = ep.major_id
                         AND col.colid = ep.minor_id
                         AND ep.name = 'MS_Description'
    LEFT JOIN sys.extended_properties epTwo ON obj.id = epTwo.major_id
                          AND epTwo.minor_id = 0
                          AND epTwo.name = 'MS_Description'
WHERE  obj.name = 'userTab'--表名(点此修改) 
ORDER BY col.colorder;

以上所述是小编给大家介绍的sql server递归子节点、父节点sql查询表结构的实例,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!

DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米

稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!

昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。

这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。

而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?