6

現在の値と以前の値を含むSQLテーブルがあります。

Id  Value1  PValue1 Value2  PValue2
1   A       A       V       V1
2   B       B1      W       W1
3   C       C1      X       X

それらを比較して、値が変更された場合は次の表に表示したいと思います。

Id  Column  Value   Pvalue
1   Value2  V       V1
2   Value1  B       B1
2   Value2  W       W1
3   Value1  C       C1

各列をループせずにSQL2008で可能ですか?

4

4 に答える 4

10

a を使用しCROSS APPLYて、データのピボットを解除できます。

SELECT t.id,
  x.Col,
  x.Value,
  x.PValue
FROM YourTable t
CROSS APPLY 
(
    VALUES
        ('Value1', t.Value1, t.PValue1),
        ('Value2', t.Value2, t.PValue2)
) x (Col, Value, PValue)
where x.Value <> x.PValue;

SQL Fiddle with Demoを参照してください。

私はピボット関数の使用が好きなので、アンピボットとピボット関数の両方を使用して結果を取得するバージョンを次に示します。

select id, 
  colname,
  value,
  pvalue
from
(
  select id, 
    replace(col, 'P', '') colName,
    substring(col, 1, PatIndex('%[0-9]%', col) -1) new_col,  
    val
  from yourtable
  unpivot
  (
    val
    for col in (Value1, PValue1, Value2, PValue2)
  ) unpiv
) src
pivot
(
  max(val)
  for new_col in (Value, PValue)
) piv
where value <> pvalue
order by id

デモで SQL Fiddle を参照してください

于 2013-02-26T14:21:41.277 に答える
6

簡単な方法は次のとおりです。

SELECT  Id, 
        'Value1' [Column],
        Value1 Value,
        PValue1 PValue
FROM YourTable
WHERE ISNULL(Value1,'') != ISNULL(PValue1,'')
UNION ALL
SELECT  Id, 
        'Value2' [Column],
        Value2 Value,
        PValue2 PValue
FROM YourTable
WHERE ISNULL(Value2,'') != ISNULL(PValue2,'')
于 2013-02-26T14:20:44.373 に答える
0

最後に、完全を期すためにUNPIVOTコマンドがあります。ただし、ピボットを解除したい列が 2 つあるため、他の解決策のいずれかを使用する方がおそらく簡単です。

于 2013-02-26T14:29:08.430 に答える
0

ユニオンを使用するのはどうですか:

SELECT * FROM
    (SELECT Id, 'Value1' [Column], Value1 [Value], PValue1 [PValue]
    FROM table_name
    UNION ALL
    SELECT Id, 'Value2' [Column], Value2 [Value], PValue2 [PValue]
    FROM table_name)tmp
WHERE Value != PValue
ORDER BY Id
于 2013-02-26T14:22:46.270 に答える