一道SQL面试题


表结构如下#

是一张递归格式的表

使用SQL转换成如下格式#

SQL实现#

使用SQL转换成上图的格式

SQL代码:

Copy
WITH T_Recur AS ( SELECT Id,1 num, cast(name as nvarchar(512)) as src , name as l1, cast('' as nvarchar(16)) l2, cast('' as nvarchar(16)) l3, cast('' as nvarchar(16)) l4 , cast('' as nvarchar(16)) l5, cast('' as nvarchar(16)) l6, cast('' as nvarchar(16)) l7 FROM [TestDB].[dbo].[Recursion] WHERE Pid is NULL UNION all SELECT r.Id, t.num+1 num,cast(t.src+r.Name as nvarchar(512)) as src ,t.l1 ,CASE WHEN t.num=1 THEN r.name when t.num>1 Then t.l2 ELSE cast('' as nvarchar(16)) END ,CASE WHEN t.num=2 THEN r.name when t.num>2 Then t.l3 ELSE cast('' as nvarchar(16)) END ,CASE WHEN t.num=3 THEN r.name when t.num>3 Then t.l4 ELSE cast('' as nvarchar(16)) END ,CASE WHEN t.num=4 THEN r.name when t.num>4 Then t.l5 ELSE cast('' as nvarchar(16)) END ,CASE WHEN t.num=5 THEN r.name when t.num>5 Then t.l6 ELSE cast('' as nvarchar(16)) END ,CASE WHEN t.num=6 THEN r.name when t.num>6 Then t.l7 ELSE cast('' as nvarchar(16)) END from [TestDB].[dbo].[Recursion] r JOIN T_Recur t on r.PId=t.Id ) select l1 '一级部门', l2 '二级部门', l3 '三级部门', l4 '四级部门', l5 '五级部门', l6 '六级部门', l7 '七级部门' from T_Recur -- 多送三个部门

结束#

我觉得挺离谱的,这是线上的笔试,离开笔试界面会有警告⚠,我就没用开发工具写,相当于是手写SQL了。
我当时没写出来,好久没用case,都用错了。当时case的判断我是用的==,正确写法是单等号=。我当时就随便写了一段case代码和递归SQL,然后说明了一下实现思路用case+cte实现。

posted @   寻己Tenleft  阅读(118)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示
目录