2017-03-03 6 views
3

3つのテーブル、テーブル1、テーブル2、テーブル3があります。テーブル1にはすべての既存レコードが記録され、テーブル2にはテーブルに適用されるデルタ(新しい更新)テーブルの違いによって異なる列を更新する方法

表3は、結果の表である。

表1および3の構造:IDを主キー ID、日付、場所、年齢、カウントされ、変更タイプ:IDは

表2構造を数え、主キー ID、日付、場所、年齢であります

表2のレコードのみたとえば表1

を変更されたフィールドのための新しい更新値:

表1

1, 03/03/2017, A, 11, 1 
2, 01/03/2017, B, 39, 1 
3, 01/01/2017, D, 1, 1 

表2

2, 03/03/2017,NULL, NULL,2, Update 
1, NULL, CC, NULL, NULL, Update 

したがって表3は、任意の提案が理解されるであろう

1, 03/03/2017, CC, 11, 1 
2, 03/03/2017, B, 39, 2 
3, 01/01/2017, D, 1, 1 

であるべきです。

GO 
/****** Object: Table [dbo].[Table_1] Script Date: 03/03/2017 10:41:28 ******/ 
SET ANSI_NULLS ON 
GO 
SET QUOTED_IDENTIFIER ON 
GO 
CREATE TABLE [dbo].[Table_1](
    [ID] [int] NOT NULL, 
    [date] [date] NULL, 
    [location] [nvarchar](50) NULL, 
    [age] [int] NULL, 
    [count] [int] NULL 
) ON [PRIMARY] 

GO 
/****** Object: Table [dbo].[Table_2] Script Date: 03/03/2017 10:41:28 ******/ 
SET ANSI_NULLS ON 
GO 
SET QUOTED_IDENTIFIER ON 
GO 
CREATE TABLE [dbo].[Table_2](
    [ID] [int] NOT NULL, 
    [date] [date] NULL, 
    [location] [nvarchar](50) NULL, 
    [age] [int] NULL, 
    [count] [int] NULL, 
    [ChangeTyppe] [nvarchar](10) NULL 
) ON [PRIMARY] 

GO 
/****** Object: Table [dbo].[Table_3] Script Date: 03/03/2017 10:41:28 ******/ 
SET ANSI_NULLS ON 
GO 
SET QUOTED_IDENTIFIER ON 
GO 
CREATE TABLE [dbo].[Table_3](
    [ID] [int] NOT NULL, 
    [date] [date] NULL, 
    [location] [nvarchar](50) NULL, 
    [age] [int] NULL, 
    [count] [int] NULL 
) ON [PRIMARY] 

GO 
INSERT [dbo].[Table_1] ([ID], [date], [location], [age], [count]) VALUES (1, CAST(0x863C0B00 AS Date), N'A', 11, 1) 
GO 
INSERT [dbo].[Table_1] ([ID], [date], [location], [age], [count]) VALUES (2, CAST(0x843C0B00 AS Date), N'B', 39, 1) 
GO 
INSERT [dbo].[Table_1] ([ID], [date], [location], [age], [count]) VALUES (3, CAST(0x493C0B00 AS Date), N'D', 1, 1) 
GO 
INSERT [dbo].[Table_2] ([ID], [date], [location], [age], [count], [ChangeTyppe]) VALUES (2, CAST(0x863C0B00 AS Date), NULL, NULL, 2, N'Update') 
GO 
INSERT [dbo].[Table_2] ([ID], [date], [location], [age], [count], [ChangeTyppe]) VALUES (1, NULL, N'CC', NULL, NULL, N'Update') 
GO 

答えて

2

必要なのは1回限りであれば、これはうまくいくはずです。

左プライマリキーで2つのテーブルを結合し、NULLでない場合はT2から値を取得します。 2からの値がヌルの場合、T1から値を取得します。

Coalesceは、nullではない最初の値を返します。

行がT2に存在しなかった場合、またはT2の値がnullの場合(IDごとに)、値はNULLになります。

INSERT dbo.Table_3 
     (ID, date, location, age, count) 
SELECT t1.ID , 
     [date] = COALESCE(t2.date, t1.date) , 
     [location] = COALESCE(t2.location, t1.location) , 
     [age] = COALESCE(t2.age, t1.age) , 
     [count] = COALESCE(t2.count, t1.count) 
FROM dbo.Table_1 t1 
LEFT OUTER JOIN dbo.Table_2 t2 ON t2.ID = t1.ID 
+0

+1、要求された更新のための動作を追加するために、あなただけの '左join'から最後に'インナーjoin' – SqlZim

+0

に 'update'とスイッチへの挿入からそれを変更します、私は更新でISNULL()を使用しました。すべての助けに感謝します。 –

関連する問題