SQL2008新特性之---merge

本文详细介绍了如何使用 SQL 的 MERGE 语句来高效地实现两张表之间的数据同步。通过具体的示例代码,展示了如何进行数据更新、插入及删除操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ContractedBlock.gifExpandedBlockStart.gifCode
MERGE dbo.table AS im --对比表
USING (SELECT * FROM dbo.table_MID with(nolock) ) AS src --
ON im.ProductID = src. ProductID
WHEN MATCHED THEN
UPDATE SET im.ProductID = src. ProductID
,im.BrandName
=src.BrandName
,im.ProductName 
= src.ProductName
,im.ProductType
=src.ProductType
,indate
=getdate()
WHEN NOT MATCHED THEN
INSERT (ProductID,BrandName,Series,ModelNumber,ProductName,ProductType,Category,indate)
VALUES (src.ProductID,src.BrandName,src.Series,src.ModelNumber,src.ProductName,src.ProductType,src.Category,src.indate)

WHEN NOT MATCHED BY SOURCE then delete;

 

如上,MERGE函数可以很方便的帮我们实现2张表数据的同步。

 以上src是我们的源表,im是我们操作的目标表。

我们只需要设置相关条件,然后就可以很轻松的实现对目标表的数据的更新、插入、删除操作。

是不是很easy啊!

转载于:https://www.cnblogs.com/kaiwind/archive/2009/11/02/1594453.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值