将目录滚动到父级

时间:2016-09-07 13:31:47

标签: sql sql-server

有没有办法滚动数据,如下所示:

enter image description here

我正在寻找的是:

Y:\ Data \ FS02-V \ Aetna \ ETL |数据,开发文件

因此,第一行的第二行和第三行应该汇总到父级,父级应该显示包含的所有文件类型。我在sql server中工作,这是生成源表的代码:

      SELECT
         [MCL].[Category Description] As Category
        , [SF].[Directory] as Directory
        , CONVERT(BIGINT, [SF].[Length]) AS FileSize 
        , (SELECT MAX([Id]) FROM [dbo].[split](RIGHT([SF].[Directory],LEN([SF].[Directory])-1),'\')) AS [LevelsFromRoot]
    FROM [dbo].[FS02V_SourceFiles] [SF]
    INNER JOIN [dbo].[Extensions] [E]
        ON [SF].[Extension] = [E].[Extension]
    INNER JOIN [dbo].[MasterCategoryLookup] [MCL]
        ON [MCL].CategoryID = [E].Category
    ORDER BY [SF].[Directory]

表格def:

CREATE TABLE [dbo].[FS02V_SourceFiles](
    [Length] [float] NULL,
    [Directory] [nvarchar](255) NULL,
    [Extension] [nvarchar](255) NULL,
    [Type] [nvarchar](max) NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]


CREATE TABLE [dbo].[Extensions](
    [Extension] [nvarchar](255) NULL,
    [Type] [nvarchar](max) NULL,
    [Category] [int] NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

分割功能:

ALTER FUNCTION [dbo].[Split]
(
    @RowData nvarchar(max),
    @SplitOn nvarchar(5)
) 
RETURNS @RtnValue table 
(
    Id int identity(1,1),
    Data nvarchar(max)
) 
AS 
BEGIN 
    Declare @Cnt int
    Set @Cnt = 1

    While (Charindex(@SplitOn,@RowData)>0)
    Begin
        Insert Into @RtnValue (data)
        Select 
            Data = ltrim(rtrim(Substring(@RowData,1,Charindex(@SplitOn,@RowData)-1)))

        Set @RowData = Substring(@RowData,Charindex(@SplitOn,@RowData)+1,len(@RowData))
        Set @Cnt = @Cnt + 1
    End

    Insert Into @RtnValue (data)
    Select Data = ltrim(rtrim(@RowData))

    Return
END

路径(目录)存储为nvarchar,它应该是汇总到父级的驱动程序。我认为路径需要拆分,我的功能已经做了类似的事情来获得路径级别。我认为使用我的原始数据在SQL中会更容易,但在一天结束时我将在tableau中可视化这些数据,所以如果有人知道在我将它提供到tableau之前是否更容易使用sql或只是使用使用我的源数据的表格我也会尝试。

1 个答案:

答案 0 :(得分:0)

解决这个问题很简单:

使用abolve SQL准备目录并将它们与各自的文件分组,然后使用Tableau和计算字段将其汇总。