SQL 多级查询(级数不定)

SQL 多级查询(级数不定),第1张

select from item where itemID=3 union all

select from item where FDetail=0 and parentID <(select parentID from item where itemID=3)

and substring(Number,1,2) =(select substring(Number,1,2) from item where itemID=3)

and substring(Number,4,2) =(select substring(Number,4,2) from item where itemID=3);

说下思路,先把自己本身一条找出来,然后找他的上级,看你的数据知道parentID 一定小于本身的parentID ,并且是目录的话FDetail=0,如果是其上级目录,他们前边的0101什么的都是一样的,但是现在有个弊端,就是查询前,要确定这个itemID=3的是属于第几级实体,然后才能采用后边用多少个substring,另一个表itemID=3的条件没用,其实就是一个嵌套,你自己写里边吧

类似这种语法,你可以参考一下:

WITH leaderCTE as(

SELECT id, name,manager

FROM [lulinghao][dbo][YGB]

WHERE name = @name

UNION ALL

SELECT ygbid, ygbname,ygbmanager

FROM [lulinghao][dbo][YGB] as ygb

inner join leaderCTE lce on lcemanager = ygbid

)

SELECT case when [id]=100 then 1 when [id]=101 OR [id]=102 then 2 else 3 end as leaderlevel,

name as leadername

FROM leaderCTE

在程序中通过sql语句查询来获得某个数据库的所有表名,代码如下:

SELECT

table_name

FROM

information_schematables

WHERE table_schema = 'mydatabasename'

AND table_type = 'base table'

扩展资料

1,利用systables目录视图查询所有表的名字,systables目录视图为每个表对象返回一行 示例语句如下:

select from systables

注意:systables目录视图也只有在SQL SERVER2005及以上的版本中才能使用。

2,利用存储过程sp_tables sp_tables存储过程,可返回可在当前环境中查询的对象列表。这代表可在FROM子句中出现的任何对象。 我们可以执行如下语句:

exec sp_tables

在结果集中筛选出所有TABLE_TYPE等于TABLE的记录就是表信息了。

参考资料:

百度百科 sql语句

百度百科 systables

以上就是关于SQL 多级查询(级数不定)全部的内容,包括:SQL 多级查询(级数不定)、高难!小白求救,sql 每层有一到三个下级如何查询子树、怎么用Sql语句获取一个数据库中的所有表的名字等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/9763291.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存