首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >更新时oracle中的求和和条件

更新时oracle中的求和和条件
EN

Stack Overflow用户
提问于 2014-01-19 13:52:51
回答 2查看 81关注 0票数 0

我正在从事甲骨文数据库系统的工作,我必须这样做:所有员工都根据其雇用日期获得加薪,具体如下:(使用一条SQL语句)如果雇员在2001年后被雇用,则加薪10%。如果雇员在1997至2000年间被雇用,工资将增加7%。如果雇员在1996年之前被雇用,则增加4%的工资。

我使用了以下代码

代码语言:javascript
复制
update employee set salary = case 
when hire_date>'1-1-2001' then salary=salary+salary*0.1
when hire_date between ('1-1-1997','1-1-2000') then salary=salary+salary*0.07
when hire_date < '1-1-1996' then salary=salary+salary*0.04
end

这是怎么回事??

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-01-19 14:11:47

尝试:

代码语言:javascript
复制
update stackoverflow_employee set salary = case 
when hire_date>'1-Jan-2001' then salary+salary*0.1
when hire_date between ('1-Jan-1997') AND ('1-Jan-2000') then salary+salary*0.07
when hire_date < '1-Jan-1996' then salary+salary*0.04
end

要记住的要点:

  1. X与X之间运算符的正确使用
  2. 日期格式为2012年1月1日至2012年
  3. 在使用salary=“case语句”时,不要在这种情况下使用salary= salary+salary*0.04 wihin。

希望现在您的查询正在工作:)

票数 1
EN

Stack Overflow用户

发布于 2014-01-19 16:17:18

我会把它写成:

代码语言:javascript
复制
update employee
    set salary = (salary * (case when hire_date >= '2001-01-01' then 1.10
                                 when hire_date >= '1997-01-01' then 1.07
                                 else 1.04
                            end)
                 );

这解决了salary =和funky between子句的明显问题。它还会进入case语句,这是只需要存在的逻辑--增加的数量。Tt通过利用between语句返回第一个匹配的事实来删除case。最后,采用ISO标准的日期格式。

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

https://stackoverflow.com/questions/21217614

复制
相关文章

相似问题

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