sql 要將兩個或者多個表的數據聯系關系,然后,點竄別的一個表數據時,需要用到如下布局:
UPDATE ...
SET ...
FROM xxx, xxxx
WHERE ...
【若是存在測試姑且表,則先刪除,便于反復執行SQL】:
IF OBJECT_ID('tempdb..#SourceTable1') IS NOT NULL DROP TABLE #SourceTable1;
IF OBJECT_ID('tempdb..#SourceTable2') IS NOT NULL DROP TABLE #SourceTable2;
IF OBJECT_ID('tempdb..#UpdateTable') IS NOT NULL DROP TABLE #UpdateTable;
【建立源表1】:
CREATE TABLE #SourceTable1(
Id UNIQUEIDENTIFIER,
SCode VARCHAR(50),
SName NVARCHAR(100),
Remark NVARCHAR(500)
)
【建立源表2】:
CREATE TABLE #SourceTable2(
Id UNIQUEIDENTIFIER,
SCode VARCHAR(50),
SAttr1 VARCHAR(100),
SAttr2 VARCHAR(100)
)
【建立需要更新數據的表】:
CREATE TABLE #UpdateTable(
Id UNIQUEIDENTIFIER,
SCode VARCHAR(50),
SName NVARCHAR(100),
SAttr1 VARCHAR(100),
SAttr2 VARCHAR(100)
)
【插入源表1測試數據】:
INSERT INTO #SourceTable1(Id, SCode, SName, Remark) VALUES(NEWID(), 'SCode1', '更新名字1', '更新測試備注1');
INSERT INTO #SourceTable1(Id, SCode, SName, Remark) VALUES(NEWID(), 'SCode2', '更新名字2', '更新測試備注2');
INSERT INTO #SourceTable1(Id, SCode, SName, Remark) VALUES(NEWID(), 'SCode3', '更新名字3', '更新測試備注3');
-- 查詢插入的成果
SELECT * FROM #SourceTable1
【插入源表2測試數據】:
INSERT INTO #SourceTable2(Id, SCode, SAttr1, SAttr2) VALUES(NEWID(), 'SCode1', 'SCode1-更新屬性1', 'SCode1-更新屬性2');
INSERT INTO #SourceTable2(Id, SCode, SAttr1, SAttr2) VALUES(NEWID(), 'SCode2', 'SCode2-更新屬性1', 'SCode2-更新屬性2');
-- 查詢插入的成果
SELECT * FROM #SourceTable2
【插入#UpdateTable的原始記實】:
INSERT INTO #UpdateTable(Id, SCode, SName, SAttr1, SAttr2) VALUES(NEWID(), 'SCode1', '名字1', 'SCode1-屬性1', 'SCode1-屬性1');
INSERT INTO #UpdateTable(Id, SCode, SName, SAttr1, SAttr2) VALUES(NEWID(), 'SCode2', '名字2', 'SCode2-屬性2', 'SCode2-屬性2');
INSERT INTO #UpdateTable(Id, SCode, SName, SAttr1, SAttr2) VALUES(NEWID(), 'SCode3', '名字3', 'SCode3-屬性3', 'SCode3-屬性3');
-- 查詢插入的成果
SELECT * FROM #UpdateTable
【利用結合查詢,將#UpdateTable、源表1、2中不異SCode的行字段更新到表#UpdateTable】:
UPDATE ut
SET ut.SName = sc1.SName,
ut.SAttr1 = sc2.SAttr1,
ut.SAttr2 = sc2.SAttr2
FROM #UpdateTable ut, #SourceTable1 sc1, #SourceTable2 sc2
WHERE ut.SCode = sc1.SCode
AND ut.SCode = sc2.SCode
-- 查詢插入的成果
SELECT * FROM #UpdateTable
0 篇文章
如果覺得我的文章對您有用,請隨意打賞。你的支持將鼓勵我繼續創作!