一个sql查询语句(转)
当时有一个表,表大致是长这样的:
GroupID SectionID CreatedTime TextValue ----------- ----------- ------------------------ ----------- 1 1 2007-07-10 00:00:00.000 1-1-07-10 1 1 2007-07-11 00:00:00.000 1-1-07/11 1 2 2007-07-05 00:00:00.000 1-2-07/05 1 2 2007-07-11 00:00:00.000 1-2-07-11 1 3 2007-07-13 00:00:00.000 1-3-07-13 2 1 2007-07-10 00:00:00.000 2-1-07-10 2 1 2007-07-11 00:00:00.000 2-1-07-11 2 4 2007-07-09 00:00:00.000 2-4-07-09
其中GroupID, SectionID和CreatedTime是联合主键。当时希望写一个简单的查询,不用CURSOR、不用临时表和临时表变量,希望能得到这样的查询结果:
GroupID SectionID CreatedTime TextValue ----------- ----------- -------------------------- --------- 2 4 2007-07-09 00:00:00.000 2-4-07-09 2 1 2007-07-11 00:00:00.000 2-1-07-11 1 3 2007-07-13 00:00:00.000 1-3-07-13 1 2 2007-07-11 00:00:00.000 1-2-07-11 1 1 2007-07-11 00:00:00.000 1-1-07/11
也就是说,对于每一种(GroupID, SectionID)的组合,取出最后插入的那行。
答案如下:
SELECT * FROM TableInterview AS t1 Where EXISTS ( SELECT MAX(CreatedTime) FROM TableInterview AS t2 GROUP BY GroupId, SectionId HAVING GroupId = t1.GroupId and SectionId = t1.SectionId and max(CreatedTime) = t1.CreatedTime )
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· 因为Apifox不支持离线,我果断选择了Apipost!