sql update 编号前增加数字前缀等 根据相同字段更新不同字段

一、int类型比如11在前边都加上301(变成30111),需要先把int转成字符串型添加301以后再转换成int类型

------------------------

UPDATE [tb].[dbo].[a]
SET code = convert(int,'301'+convert(nvarchar(50),code))
 WHERE name='a'


二、A.c1与B.c1相等,用一条sql语句,实现A.c2的值更新为B.c3
------------------------

UPDATE    A
SET A.c2 =B.c3
from A ,B
where A.c1=B.c1



UPDATE    A
SET A.c2 =B.c3
from A inner join B on A.c1=B.c1


根据一个表日期中13号查出的其中一个字段更新到23号这个字段,同理只是把A,B用同一个表

------------------------

UPDATE A
SET A.c1 =B.c1
from [KQ] A inner join [KQ] B on A.[考勤号码]=B.[考勤号码] 
where A.[date] ='2013-01-23' and B.[date]='2013-01-13' and A.company='北京' 

Update中使用Case语句

UPDATE Personnel
SET salary = CASE WHEN salary >= 5000
             THEN salary * 0.9
WHEN salary >= 2000 AND salary < 4600
THEN salary * 1.15
ELSE salary END

这里要注意一点,最后一行的ELSE salary是必需的,要是没有这行,不符合这两个条件的人的工资将会被写成NUll,那可就大事不妙了。

一张表求出的和,更新到另一张表(聚合函数查询的结果,作为B表更新A表中的数据)

update A
SET A.Score = B.sum1
FROM A,(SELECT [name]
      ,[code]
      ,[name]
      ,sum(convert(int,[value]) ) as sum1
  FROM [Score]
  where [name]='条件'
  group by [name]
      ,[code],[name]) B 
WHERE A.code = B.[code]  and A.code in('12345678')



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值