SQL Serverは、結果セットを総称的に分析するのにはあまり役に立ちません。動的なSQLがあり、そこにはありますか? - XML。私は、未知のセットを扱うXMLの能力に本当に感謝しています!
DECLARE @tbl1 TABLE(ID INT,Value1 VARCHAR(10),Value2 VARCHAR,PointInTime DATETIME);
INSERT INTO @tbl1 VALUES
(1,'a','b',{d'2017-01-01'})
,(2,'a','b',{d'2017-01-02'})
,(3,'a','x',{d'2017-01-03'})
,(4,NULL,'b',{d'2017-01-04'})
DECLARE @tbl2 TABLE(ID INT,Value1 VARCHAR(10),Value2 VARCHAR,PointInTime DATETIME);
INSERT INTO @tbl2 VALUES
(1,'a','b',{d'2017-01-01'})
,(2,NULL,'b',{d'2017-01-02'})
,(3,'a','x',{d'2017-01-03'})
,(4,'y','b',{d'2017-01-05'});
- このはモミテーブル
DECLARE @xml1 XML=
(
SELECT *
FROM @tbl1 AS tbl
FOR XML RAW,ELEMENTS XSINIL,TYPE
);
--check出力
/*
SELECT @xml1;
<row xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<ID>1</ID>
<Value1>a</Value1>
<Value2>b</Value2>
<PointInTime>2017-01-01T00:00:00</PointInTime>
</row>
[...more rows..]
*/
--SameとからXMLを作成します。第2表
DECLARE @xml2 XML=
(
SELECT *
FROM @tbl2 AS tbl
FOR XML RAW,ELEMENTS XSINIL,TYPE
);
T-SQL Serverのあとで--TwoのCTEが簡単に
WITH AllVals1 AS
(
SELECT nd.value(N'(../*[local-name()=sql:variable("@rowIDName")])[1]',N'nvarchar(max)') AS RowID
,nd.value(N'local-name(.)',N'nvarchar(max)') AS ElementName
,nd.value(N'.',N'nvarchar(max)') AS ElementValue
FROM @xml1.nodes(N'/row/*') AS A(nd)
)
,AllVals2 AS
(
SELECT nd.value(N'(../*[local-name()=sql:variable("@rowIDName")])[1]',N'nvarchar(max)') AS RowID
,nd.value(N'local-name(.)',N'nvarchar(max)') AS ElementName
,nd.value(N'.',N'nvarchar(max)') AS ElementValue
FROM @xml2.nodes(N'/row/*') AS A(nd)
)
SELECT v1.RowID,v1.ElementName,v1.ElementValue AS V1,v2.ElementValue AS V2
FROM AllVals1 AS v1
FULL OUTER JOIN AllVals2 AS v2 ON v1.RowID=v2.RowID AND v1.ElementName=v2.ElementName
WHERE v1.ElementValue<>v2.ElementValue
比較することができますID-名前と値のtupels、のリストを作成
DECLARE @rowIDName NVARCHAR(100)=N'ID';
に参加するための行のIDの名前を教えて結果が示すように、それが行2「値1」の「」であり、現在、空であり、行の4「値1」が空で、現在「Y」であり、「POINTINTIMEが異なり:
RowID ElementName V1 V2
2 Value1 a
4 Value1 y
4 PointInTime 2017-01-04T00:00:00 2017-01-05T00:00:00
リード[ '以外について'](https://msdn.microsoft.com/en-us/library/ms188055.aspx) –
@ZoharPeled良いヒントですが、違いがあれば 'EXCEPT'はすべての行を返します。多くの列で、責任ある価値を見つけるのは難しいでしょう。 – Shnugo