SQL HTML Email Column Format вместо формата строки - PullRequest
1 голос
/ 20 июня 2019

Я пытаюсь выяснить, как перевернуть это из формата таблицы в формат столбца.

Привет, я знаю, как создать электронную почту SQL в формате HTML через таблицу: i.e

Customer        Address     City
Joe             123 Here     Oakland 

но мне нужно иметь возможность перевернуть это, чтобы выглядеть как

Customer:   Joe
Address:    123 Here
City:       Oakland

Я использую SQL 2012

Любая помощь будет оценена

Пожалуйста, сообщите

DECLARE @xmlinv NVARCHAR(MAX);
DECLARE @bodyinv NVARCHAR(MAX);
DECLARE @trrowinv NVARCHAR(MAX);
DECLARE @tempemaillistinv NVARCHAR(MAX);
DECLARE @subject_anomaly NVARCHAR(MAX);
SET @subject_anomaly
    = N'Inventory Adjustments ' + CAST(@COUNTSinv AS VARCHAR(3)) + N' '
      + LEFT(CONVERT(VARCHAR(10), GETDATE(), 101), 3) + SUBSTRING(CONVERT(VARCHAR(10), GETDATE(), 101), 4, 3)
      + RIGHT(CONVERT(VARCHAR(10), GETDATE(), 101), 2);
SET @xmlinv
    = CAST(
      (
          SELECT T4.product AS 'td',
                 '',
                 T4.available AS 'td',
                 '',
                 CASE
                     WHEN T4.quarantine IS NULL THEN
                         0
                     ELSE
                         T4.quarantine
                 END AS 'td',
                 '',
                 CASE
                     WHEN T4.labels IS NULL THEN
                         0
                     ELSE
                         T4.labels
                 END AS 'td',
                 '',
                 T4.MinLog AS 'td',
                 '',
                 T.available AS 'td',
                 '',
                 CASE
                     WHEN T.quarantine IS NULL THEN
                         0
                     ELSE
                         T.quarantine
                 END AS 'td',
                 '',
                 CASE
                     WHEN T.labels IS NULL THEN
                         0
                     ELSE
                         T.labels
                 END AS 'td',
                 '',
                 T.MinLog AS 'td'
          --SELECT T4.product,T4.available,T4.quarantine,T4.labels,T4.MinLog,T.available,T.quarantine,T.labels,T.MinLog 
          FROM #t4 AS T4
              LEFT OUTER JOIN #t3 AS T3
                  ON T4.MaxRow2 = T3.MaxRow
                     AND T4.product = T3.product
              LEFT OUTER JOIN #t2 AS T2
                  ON T4.MaxRow2 = T2.MaxRow
                     AND T4.product = T2.product
              LEFT OUTER JOIN #temp AS T
                  ON T4.MaxRow2 = T.therow + 1
                     AND T4.product = T.product
          ORDER BY 1
          --ORDER BY 1,3 desc
          FOR XML PATH('tr'), ELEMENTS
      )
AS
NVARCHAR(MAX));

SET @bodyinv
    = N'<html><H2>Adjustments</H2><body bgcolor=white><table border=1  style=''border:1px;background-color:#FFFFCC;bordercolor:#FFCC00'' cellpadding=''1'' cellspacing=''0''>';
SET @trrowinv
    = N'<tr><th>Product</th><th>NewAvailable</th><th>NewQuarantine</th><th>NewLabels</th><th>LastUpdate</th><th>OldAvailable</th><th>OldQuarantine</th><th>OldLabels</th><th>PriorUpdate</th></tr>';
SET @bodyinv = @bodyinv + @trrowinv + @xmlinv + N'</table></body></html>';

SET @tempemaillistinv = N'abc@abc.com';
EXEC [msdb].[dbo].[sp_send_dbmail] @recipients = @tempemaillistinv,
                                   @body = @bodyinv,
                                   @body_format = 'HTML',
                                   @subject = @subject_anomaly,
                                   @profile_name = 'abc';
...