超碰人人人人人,亚洲AV午夜福利精品一区二区,亚洲欧美综合区丁香五月1区,日韩欧美亚洲系列

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

[點晴永久免費OA]SQLServer 批量修改或插入

freeflydom
2023年7月15日 10:24 本文熱度 1427

場景

今天在工作中遇到這么一個場景,我需要根據(jù)條件對表A做批量更新或插入。因為條件比較復雜,所以我使用了臨時表B,先把需要更新或插入的數(shù)據(jù)查詢出來放入臨時表。然后更新表A的某字段,更新條件是A.id = B.id,更新效果是若記錄存在表A中,則更新表A的字段,若不在表A中,則插入一條記錄到表A。

初始方案

首先想到的是寫兩條SQL:

  1. update使用A.id in (select id from B),這時會更新所有存在的記錄的字段,不存在則不更新

  2. 接下來再使用insert,條件是A.id not in (select id from B),把A不存在未更新的數(shù)據(jù)插入到A

兩條SQL執(zhí)行完,則完成了所有數(shù)據(jù)的更新和插入。

優(yōu)化方案

使用SQL Server Merge語句

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);



該文章在 2023/7/15 10:24:07 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運作、調(diào)度、堆場、車隊、財務費用、相關(guān)報表等業(yè)務管理,結(jié)合碼頭的業(yè)務特點,圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved