sql - 我是否需要递归 CTE 来更新依赖于自身的表?

标签 sql sql-server t-sql sql-server-2008-r2

我需要为这个标题道歉。我花了很多心思,但没有走得太远。

我有一个如下所示的表格:

+--------------------------------------+--------------------------------------+--------------------------------------+--------------------------------------+--------+
|              accountid               |             pricexxxxxid             |              accountid               |             pricelevelid             | counts |
+--------------------------------------+--------------------------------------+--------------------------------------+--------------------------------------+--------+
| 36B077D4-E765-4C70-BE18-2ECA871420D3 | 00000000-0000-0000-0000-000000000000 | 36B077D4-E765-4C70-BE18-2ECA871420D3 | F43C47CE-28C6-42E2-8399-92C58ED4BA9D |      1 |
| EBC18CBC-2D2E-44CB-B36A-0ADE9E2BDE9F | 00000000-0000-0000-0000-000000000000 | EBC18CBC-2D2E-44CB-B36A-0ADE9E2BDE9F | 3BEEA9D3-F26B-47E4-88FA-A2AA366980ED |      1 |
| 8DC8D0FC-3138-425A-A922-2F0CAC57E887 | 00000000-0000-0000-0000-000000000000 | 8DC8D0FC-3138-425A-A922-2F0CAC57E887 | F1B8AD5D-B008-4C3F-94A0-AD3F90C777D7 |      1 |
| 8F908A92-1327-4655-BAE4-C890D971A554 | 00000000-0000-0000-0000-000000000000 | 8F908A92-1327-4655-BAE4-C890D971A554 | 2E0EC67E-5F8F-4305-932E-BBF8DF83DBEC |      1 |
| 37221AAC-B885-4002-B7D9-591F8C14D019 | 00000000-0000-0000-0000-000000000000 | 37221AAC-B885-4002-B7D9-591F8C14D019 | F4A2A0CA-FDFF-4C21-AE92-D4583DC18DED |      1 |
| 66F406B4-0D9B-40B8-9A23-119EE74B00B7 | 00000000-0000-0000-0000-000000000000 | 66F406B4-0D9B-40B8-9A23-119EE74B00B7 | 204B8570-CEBA-4C72-9B72-8B9B14AF625E |      2 |
| D0168CE3-479E-439E-967C-4FF0D701291A | 00000000-0000-0000-0000-000000000000 | D0168CE3-479E-439E-967C-4FF0D701291A | 204B8570-CEBA-4C72-9B72-8B9B14AF625E |      2 |
| 57E5F6E5-0A8A-4E54-B793-2F6493DC1EA3 | 00000000-0000-0000-0000-000000000000 | 57E5F6E5-0A8A-4E54-B793-2F6493DC1EA3 | 893F9FD2-43C9-4355-AEFC-08A62BF2B066 |      3 |
+--------------------------------------+--------------------------------------+--------------------------------------+--------------------------------------+--------+

计数升序排序。

我想用相应的pricelevelid更新全部为00000000-0000-0000-0000-000000000000的pricexxxxids。

例如,对于 accountid = 36B077D4-E765-4C70-BE18-2ECA871420D3,我希望价格xxxxid 为 F43C47CE-28C6-42E2-8399-92C58ED4BA9D。

完成后,我希望删除此记录之后 accountid = 36B077D4-E765-4C70-BE18-2ECA871420D3 的所有记录。

换句话说,在结果中,我最终会得到一个不同的 accountid 列表,其中 Pricexxxxid 会被分配来自 Pricelevelid 的相应值。

非常感谢您的指导。

最佳答案

对于你的第一个案例,请这样做!

update table
set pricexxxxids=pricelevelid.

如果我正确理解你的第二种情况:(删除重复项/选择不同的)?

delete from
(
select *,rn=row_number()over(partition by accountid order by accountid) from table
)x
where rn>1


--select distinct * from table

已编辑

select * from
(
select *,rn=row_number()over(partition by accountid order by accountid) from table
)x
where x.rn=1

已更新

  SELECT accountid,pricelevelid FROM  
    (
    (SELECT *,
    Row_number() OVER ( partition BY accountid ORDER BY counts, pricelevelid ) AS Recency 
    FROM table
    )x 
   WHERE x.Recency = 1

关于sql - 我是否需要递归 CTE 来更新依赖于自身的表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23751253/

相关文章:

sql - 在 Postgres 中更改列类型会导致 pg_attrdef 警告

c# - 选择查询以从 SQL Server 获取数据

sql - 查询将垂直更改为水平

sql-server - 消息 601 ... "Could not continue scan with NOLOCK due to data movement"。但是没有锁定! - 漏洞

SQL 外部应用条件

php - 如何在 PHP 中使用三个参数(如日期、日期和输入字段)从 mysql 数据库获取结果

sql - 是否可以创建一个 sql 脚本来创建数据库并用表填充它?

c# - 定期运行 C# 应用程序以更新数据库

sql - TSQL\XPATH - 获取 CROSS APPLY 节点(子节点)上元素的正确 XPath 索引

sql - 是否可以向表中插入任意数据?