首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用其他列的值更新表列

用其他列的值更新表列
EN

Stack Overflow用户
提问于 2014-02-18 12:41:31
回答 2查看 100关注 0票数 2

我有一张这样的桌子:

代码语言:javascript
复制
Client | Date       | Value 1 | Value 2 |
1       2013-11-08    159      159
1       2013-11-09    254      254
1       2013-12-05    512      512
1       2014-01-02    1200     1200
2       2013-11-10    189      189
2       2013-11-15    289      289
2       2013-12-22    585      585
2       2014-01-06    1650     1650

我需要更新SQL中的表,如下所示:

代码语言:javascript
复制
Client | Date       | Value 1 | Value 2 |
1       2013-11-08    159      1200
1       2013-11-09    254      1200
1       2013-12-05    512      1200
1       2014-01-02    1200     1200
2       2013-11-10    189      1650
2       2013-11-15    289      1650
2       2013-12-22    585      1650
2       2014-01-06    1650     1650

其想法是,对于每个客户端,Value 2将成为Value 1,而Date是最近出现的。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-02-18 12:53:46

在Server中,最好使用CTE和UPDATE语句。下面的查询演示了您需要做的事情的语法。您所要做的就是替换表名和列名。

代码语言:javascript
复制
;WITH    MyUpdate
          AS ( SELECT ClientId
                   ,Value1
                   ,ROW_NUMBER() OVER ( PARTITION BY ClientId ORDER BY MyDate DESC ) AS RowNum
                FROM MyTable)
    UPDATE MyTable
        SET MyTable.Value2 = MyUpdate.Value1
        FROM MyTable
        INNER JOIN MyUpdate
            ON MyUpdate.ClientID = MyTable.ClientID
               AND RowNum = 1
票数 5
EN

Stack Overflow用户

发布于 2014-02-18 12:58:11

试试这个:

代码语言:javascript
复制
UPDATE TABLE1 T2 SET Value2 =
(SELECT T1.Value2 FROM TABLE1 T1 WHERE T1.Client = T2.Client AND
T1.Date = (SELECT MAX(T3.Date) FROM TABLE1 T3 
           WHERE T2.Client = T3.Client GROUP BY Client));

甲骨文

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21854202

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档