sql在update更新时如何快速且大批量的更新数据

数据库是mssql2008我是要在C#中写的sql语句,假设有3个数组string[]A和string[]B和string[]CA数组和B数组和C数组都各有1万个元素现在... 数据库是mssql2008

我是要在C#中写的sql语句,
假设有3个数组
string[] A和string[] B和string[] C
A数组和B数组和C数组都各有1万个元素

现在在sqlserver中有一张表,假设叫表tableA
有4个字段id, colA, colB, colC
其中id是主键,colA各个值不相同,且建立了唯一索引

让colA中值等于A[i]的记录的colB和colC列对应更新为B[i], C[i]的值

我要怎么做的,

我尝试了循环执行更新和update case when这2种方法,但是我觉得速度太慢了,要4-5分钟

我要的是能快速且批量更新的
展开
 我来答
li_1011cwq2
2015-07-22
知道答主
回答量:6
采纳率:0%
帮助的人:2.6万
展开全部
使用merge语句吧
语法:
MERGE INTO 目标表 AS A

USING 源表 AS B

ON (A.COL = B.COL) --匹配条件

WHEN MATCHED THEN --当匹配上就用B表的字段更新A表的字段

UPDATE SET
A.COL1 = B.COL1,
...
A.COLn = B.COLn

WHEN NOT MATCHED THEN INSERT(A.COL1,...,A.COLn) --下面这句是不匹配就插入数据

VALUES (B.COL1,...,B.COLn);
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
今至电子科技有限公司
2024-08-23 广告
数据库备份是确保数据安全与业务连续性的关键环节。我们上海今至电子科技有限公司高度重视数据保护,定期执行全面的数据库备份策略。这包括使用先进工具和技术,对关键业务数据进行自动化备份,并存储在安全可靠的外部存储介质或云端。通过定期验证备份的完整... 点击进入详情页
本回答由今至电子科技有限公司提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式