首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
SAAS
ToB门户
了解全球最新的ToB事件
论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
微博
Follow
记录
Doing
博客
Blog
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
排行榜
Ranklist
相册
Album
应用中心
qidao123.com技术社区-IT企服评测·应用市场
»
论坛
›
软件与程序人生
›
后端开发
›
Java
›
SQLServer批量修改和插入
返回列表
发新帖
SQLServer批量修改和插入
[复制链接]
发表于 2023-7-14 13:18:15
|
显示全部楼层
|
阅读模式
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要
登录
才可以下载或查看,没有账号?
立即注册
×
SQLServer 批量修改或插入
场景
今天在工作中遇到这么一个场景,我需要根据条件对表A做批量更新或插入。因为条件比较复杂,所以我使用了临时表B,先把需要更新或插入的数据查询出来放入临时表。然后更新表A的某字段,更新条件是A.id = B.id,更新效果是若记录存在表A中,则更新表A的字段,若不在表A中,则插入一条记录到表A。
初始方案
首先想到的是写两条SQL:
update使用A.id in (select id from B),这时会更新所有存在的记录的字段,不存在则不更新
接下来再使用insert,条件是A.id not in (select id from B),把A不存在未更新的数据插入到A
两条SQL执行完,则完成了所有数据的更新和插入。
优化方案
后面有朋友提示可以使用SQL Merge语句做这件事情,由于对
数据库
并不熟悉,所以不知道还有这么一个语法。我查阅了相关资料,发现Merge确实很合适这个场景。参考
SQL Server Merge语句 - SQL Server教程 (yiibai.com)
重构了
代码
select ... into #temp
from A where ...
merge [A] a using #B b
on a.id = b.id
when matched
then update set a.field = 1
when not matched by target
then insert (field)
values (b.id);
复制
代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
继续阅读请点击广告
回复
使用道具
举报
返回列表
浏览过的版块
分布式数据库
自由的羽毛
+ 我要发帖
×
登录参与点评抽奖,加入IT实名职场社区
去登录
微信订阅号
微信服务号
微信客服(加群)
H5
小程序
快速回复
返回顶部
返回列表