加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

更新sql server数据库表中的两个重复项之一

发布时间:2020-12-12 08:44:54 所属栏目:MsSql教程 来源:网络整理
导读:我有一张表,它有一个重复值的列.我想更新一个2个重复的值,例如row1 = tom和row2 = tom ..我想添加一个或一个到其中一个,这将是同一列中的许多其他重复.基本上只需要为每1个重复项添加一个数字或字母,因此不再有重复. 我得到这个查询,将更新所有的重复,但不是
我有一张表,它有一个重复值的列.我想更新一个2个重复的值,例如row1 = tom和row2 = tom ..我想添加一个或一个到其中一个,这将是同一列中的许多其他重复.基本上只需要为每1个重复项添加一个数字或字母,因此不再有重复.

我得到这个查询,将更新所有的重复,但不是其中之一.谁能帮忙?

UPDATE Table1
   SET Column1 = 'a'
 WHERE exists
       (SELECT Column1,COUNT(Column1 )
FROM Clients
GROUP BY Column1 
HAVING ( COUNT(Column1 ) > 1)
)

解决方法

尝试使用CTE和PARTITION BY
;WITH cte AS
(
  SELECT
      ROW_NUMBER() OVER(PARTITION BY Column1  ORDER BY Column1 ) AS rno,Column1 
  FROM Clients
)

UPDATE cte SET Column1 =Column1 +' 1 '
WHERE rno=2

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读