1

のように動作するクエリを作成しようとしていますforeach

クエリ:

select label ,NTILE(10) over(order by label ASC) Quartile INTO #labelTempTab from dbo.ReportFieldsLookup

データは次のようになります。

label   Quartile
-----   --------
la1         1
la2         1
la3         1
sa1         2
sa2         2
sq3         2
ha1         3
ha2         3
ha3         3
ka1         4
ka2         4
kas3        4

クエリの継続:

DECLARE @sql nvarchar(max)

SELECT * INTO #SetValuesTable  FROM svo_tbl

SET @sql = 'SELECT MNUM, Label , LabelValue ,[Property Type] FROM #SetValuesTable '
              +' CROSS APPLY ( VALUES '
              +  stuff(( SELECT ',('''+ replace(C.label,'''','"') + ''',' + quotename(C.label) + ')'   FROM #labelTempTab c WHERE c.Quartile = 1 group by label FOR xml path('')), 1, 1, '')
              +' ) AS UPTab (Label , LabelValue);'

EXEC(@sql) 

上記のクエリはQuartile = 1 、1 から n に対して機能させ、すべての結果を結合するにはどうすればよいですか? についてのみピボットを解除します。

#SetValuesTable のデータは次のようになります。

MNUM      la1   la2     la3   sa1  sa2      sq3    ha1     ha2    ha3   ka1   ka2 Property Type 
12         1     0      2      1    0       8       3       4      0     1     2    s
13         4     0      5      1    6       8       5       2      1     1     3    p

結果(期待される出力)は次のようになります

MNUM  Label LabelValue Property Type
12     la1     1          s
12     la2     0          s
12     la3     2          s
12     sa1     1          s
12     sa2     0          s
12     sa3     8          s

........

13     ka1     1          p
13     ka2     1          p
12     ka3     3          p

クエリの続き:

SET @sql = @sql + ' INNER JOIN dbo.ReportFieldsLookup tt ON tt.label = Label'
SET @sql = @sql + 'INNER JOIN dbo.SplitStrings_Ordered('''''09-404811,10-433495,10-433575,10-423789'''', ',') AS s ON #SetValuesTable.MNum = s.MNum ORDER BY s.[Index];

上記の 2 つのステートメントには時間がかかります。特にソート用の Last inner join に時間がかかっています。クロスアプライを使用すると、実行時間が大幅に短縮される可能性があると思います。

4

1 に答える 1

1

結果のピボットを解除するために使用Cross Applyします。動的クエリ クエリは、この形式で構築する必要があります。

SELECT mnum,
       label,
       label_value,
       [Property Type]
FROM   #SetValuesTable
       CROSS apply(VALUES ('la1',la1),('la2',la2),('la3',la3),
                          ('sa1',sa1),('sa2',sa2),('sa3',sa3),
                          ('ha1',ha1),('ha2',ha2),('ha3',ha3),
                          ('ka1',ka1),('ka2',ka2)) cs (label, label_value) 

Dynamic query次のようなものでなければなりません

DECLARE @label VARCHAR(max)='',
        @sql   NVARCHAR(max)

SELECT @label += '(' + '''' + label + ''',' + label + '),'
FROM   (SELECT DISTINCT Isnull(label, '') label
        FROM   #labelTempTab)a

SELECT @label = LEFT(@label, Len(@label) - 1)

SET @sql= 'SELECT mnum,
             label,
             label_value,
             [Property Type]
    FROM   #SetValuesTable
           CROSS apply(VALUES ' + @label
          + ') cs (label, label_value) '

EXEC Sp_executesql @sql 

注:テーブルから値リストを生成しているため、テーブル#labelTempTabにすべてのラベルが存在することを確認してください#SetValuesTable

于 2015-01-27T01:53:29.190 に答える