在SQL Server中如何进行UPDATE TOP .....ORDER BY?
前言
今天在导入数据到系统后需要根据时间排序对刚导入的TOP N条进行数据更新,之前没遇到过UPDATE TOP...ORDER BY,以此作为备忘录。
SQL SERVER之UPDATE TOP...ORDER BY
我们利用AdventureWorks2012实例数据库来演示,一般情况我们如下一次性更新所有数据,如下:
SELECT * FROM Production.Product UPDATE Production.Product SET ListPrice = 1
如上我们一次性将表Production.Product中的列ListPrice更新为1,结果如下:
但是我们项目实际需求是因为之前数据库已存在对应企业下数据,当前我们导入的数据需要更新一列作为标识区分,如下:
SELECT TOP 10.* FROM Production.Product WHERE SafetyStockLevel = 1000 ORDER BY SellStartDate DESC
大意如上,将导入的数据根据SellStartDate日期倒序,并根据条件筛选刚导入的数据10条,接下来这是对其进行更新。
UPDATE TOP(10) Production.Product SET ListPrice = 1 WHERE SafetyStockLevel = 1000 ORDER BY SellStartDate DESC
到现在我才知道UPDATE不能和ORDER BY一起使用,涨知识了,又学到了一点。接下来则是解决UPDATE TOP...ORDER BY的问题。我想到了方案是根据CTE更新,如下:
;WITH Product AS ( SELECT TOP 10.* FROM Production.Product WHERE SafetyStockLevel = 1000 ORDER BY SellStartDate DESC ) UPDATE Product SET ListPrice = 1
这是解决方案中的其中之一,我们也可以如下这样做:
UPDATE Production.Product SET ListPrice = 1 WHERE ProductID IN( SELECT TOP 10 ProductID FROM Production.Product WHERE SafetyStockLevel = 1000 ORDER BY SellStartDate DESC)
或者可以如下这样做:
UPDATE Production.Product SET ListPrice = updateValue FROM (SELECT TOP 10 ProductID, 1 AS updateValue FROM Production.Product ORDER BY SellEndDate DESC ) AS t1 WHERE Production.Product.ProductID = t1.ProductID;

为了方便大家在移动端也能看到我分享的博文,现已注册个人公众号,扫描上方左边二维码即可,欢迎大家关注,有时间会及时分享相关技术博文。
感谢花时间阅读此篇文章,如果您觉得这篇文章你学到了东西也是为了犒劳下博主的码字不易不妨打赏一下吧,让楼主能喝上一杯咖啡,在此谢过了!
如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!
本文版权归作者和博客园共有,来源网址:http://www.cnblogs.com/CreateMyself)/欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
你所看到的并非事物本身,而是经过诠释后所赋予的意义
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
2016-05-11 Form authentication(表单认证)问题