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的记录就是表信息了。
参考资料:
百度百科 systables
以上就是关于SQL 多级查询(级数不定)全部的内容,包括:SQL 多级查询(级数不定)、高难!小白求救,sql 每层有一到三个下级如何查询子树、怎么用Sql语句获取一个数据库中的所有表的名字等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)