注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

小新之家

心灵的放松地点

 
 
 

日志

 
 

SQL server 数据字段累加  

2009-11-06 09:40:46|  分类: 学习资料 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

表形式如下:
Year      Salary
2000        1000
2001        2000
2002        3000
2003        4000
想得到如下形式的查询结果
Year      Salary
2000      1000
2001      3000
2002      6000
2003      10000
sql语句怎么写?
题目是要对salary列进行一个逐年的累加.
经过分析可以做如下处理  表名为 yearSalary

写法一:select a.year year, sum(b.d) salary from yearSalary a, (select a.year,sum(a.salary) d from a Group by year) b where a.year>b.year group by a.year

写法二:select a.years years,(select sum(salary) from salary b where b.years<=a.years) sumSalary from salary a
sql结构分析:将问题分解,首先应该得到累加的结果,然后再排序;首先求累加,累加的约束条件是比当前记录中年份小的进行累加,那么可以用select sum(salary) from salary b where b.years<=a.years,a当然是指嵌套在外面的表了,类似递归的意味.这一步做完后其实工作已经做完了
感觉写法二很简约,不过了写法一更规范更易懂.
刚看到一个写法三 SELECT   b.years, SUM (a.salary) salary FROM salary a, salary b  WHERE a.years <= b.years GROUP BY b.years 挺不错

  评论这张
 
阅读(1825)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017