2

1か月間毎日データをtable1保存または更新するという名前のマスター テーブルが 1 つあります。mobileNo

;WITH table1 AS (SELECT * FROM (VALUES
(9999999999, '01/10/2013', NULL, NULL, NULL, NULL),
(9999999999, NULL, '02/10/2013', NULL, NULL, NULL),
(9999999999, NULL, NULL, '03/10/2013', NULL, NULL),
(9999999999, NULL, NULL, NULL, '04/10/2013', NULL),
(9999999999, NULL, NULL, NULL, NULL, '30/10/2013'),
(9999999999, NULL, NULL, NULL, NULL, NULL),
(8888888888, '01/10/2013', NULL, NULL, NULL, NULL),
(8888888888, NULL, '02/10/2013', NULL, NULL, NULL),
(8888888888, NULL, NULL, '03/10/2013', NULL, NULL),
(8888888888, NULL, NULL, NULL, '04/10/2013', NULL),
(8888888888, NULL, NULL, NULL, NULL, '30/10/2013')) 
as t(mobileno,date1,date2,date3,date4,date30))

そして、table1 に対してtable2 一意に保つという名前の別のテーブルがあります。にデータが存在するかどうかに対してmobileNo更新したいと思います。table2table1table1

mobileno        date1      date2      date3      date4      date30
--------------- ---------- ---------- ---------- ---------- ----------
8888888888      01/10/2013 02/10/2013 03/10/2013 04/10/2013 30/10/2013
9999999999      01/10/2013 02/10/2013 03/10/2013 04/10/2013 30/10/2013

しかし、私はこのようなクエリを試しました

UPDATE table1
set table1.date1 = 
(SELECT date1 from table2 where table2.mobileno = table1.mobileno) 
Where table2.mobileno = table1.mobileno

30 の番号を更新するために繰り返さずに単一のクエリで更新するにはどうすればよいですか。の日付列について、私を助けてください。前もって感謝します。

4

1 に答える 1

10

おそらく、次の UPDATE ステートメントを使用して、TABLE2 の NULL 値を回避し、TABLE1 の NOT NULL 値を更新できます。

前回の投稿にISNULL関数のみ追加

update table1
set 
    date1 = ISNULL(t2.date1, date1),
    date2 = ISNULL(t2.date2, date2)
from table2 t2
where table1.mobileno = t2.mobileno
于 2013-09-24T06:28:16.647 に答える