Change is constant - 变化时唯一的永恒

sql 批量操作(存在的更新,不存在的插入)

 

标签: sql
分类:
[sql] view plain copy
 
  1. update A SET A.NAME=  
  2. (  
  3.     select B.NAME from #tmpTB2 B where B.ID=A.ID  
  4. )  
  5. FROM #tmpTB3 A  
  6.   
  7. insert into #tmpTB3   
  8. select * from #tmpTB2 B  
  9. where B.ID not in(select ID from #tmpTB3)  
以上为:存在的更新,不存在的插入


以下为 批量更新某个标识字段:

 

[sql] view plain copy
 
  1. UPDATE A SET A.Provider_IsActive=  
  2. (  
  3.     SELECT CASE WHEN  
  4.     (  
  5.         SELECT 1 FROM  
  6.         (  
  7.             SELECT DISTINCT Provider_System_Provider_Id   
  8.             FROM YOUR_DB_NAME.[dbo].[YOUR_TABLE_NAME2] P   
  9.             WHERE p.data_source = 'ika' and soft_delete_flag = 'n' and Provider_Active_Flag = 'y'  
  10.         ) B WHERE B.Provider_System_Provider_Id = left(A.External_provider_id,7)  
  11.     ) IS NULL THEN 0 ELSE 1 END AS Provider_IsActive  
  12. )  
  13. FROM YOUR_DB_NAME.[dbo].[YOUR_TABLE_NAME1] A  
  14.   
  15. -- SELECT COUNT(*) FROM YOUR_DB_NAME.[dbo].[YOUR_TABLE_NAME1] A WHERE Provider_IsActive=0  
posted @ 2016-04-15 15:08  人海灬  阅读(1168)  评论(0编辑  收藏  举报