from - t sql cross join



Passa attraverso una tabella usando Cross apply e UNION ALL i risultati (1)

Usa Cross Apply per annullare il risultato. La query di query dinamica dovrebbe essere costruita in questo formato.

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 dovrebbe essere qualcosa di simile

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 

Nota: poiché stai creando un elenco di valori dalla tabella #labelTempTab , assicurati di avere tutte le etichette presenti nella tabella #SetValuesTable

https://src-bin.com

Cercando di scrivere una query che si comporterà come un foreach

Domanda:

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

I dati saranno come:

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

Continuazione della query:

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) 

La query sopra riportata verrà annullata solo per Quartile Quartile = 1 Come posso farlo funzionare per 1 a n e riunire tutti i risultati.

i dati in #SetValuesTable saranno simili a:

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

Il risultato (Output previsto) dovrebbe essere simile

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

continuazione della query:

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];

Le suddette due dichiarazioni richiedono molto tempo. Soprattutto l'ultimo inner join che è per l'ordinamento richiede molto tempo. Penso che l'utilizzo di cross application potrebbe ridurre notevolmente i tempi di esecuzione.





cross-apply