【SqlServe】批量修改数据,每条数据对应不同值

问题描述:一次性修改表内数据,每条数据都有指定的值
表字段展示:Id,Name
sql serve 语句:

update tableName set Name= case Id  when 1 then '第一' else '' end

//拆解
update tableName          //表名称
 set Name=                 //希望修改的列
 case Id                   //条件约束
 when 1 then '第一'         //如果case 后面没有列名,那么此处应该写为 when Id=1 then '第一'
 else '' end                //如果字段不能为空,记得一定要写上else

//上述语句表达的是: 修改表中的Name字段的值,Id=1的字段的Name修改为‘第一’,其他的都设置为空
//C# 拼接sql
var sql = $"update tableName set Name = case Id ";
foreach (var item in dic)
{
    sql += $" when {item.Key} then {item.Value}";
}
sql += $" else 0 end";

return _Repository.GetConnection().Execute(sql);

完结撒花~

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值