oracle判断为周一_oracle sql技巧:取上周一到上周日(本周一到本周日\下周一到下周日)的时间...

/**

*

* @param anObject:  thisWeek=本周;nextWeek=下周

* @return monday

*/

public String getMonday(String anObject){

String sql="";

String time="";

if("thisWeek".equals(anObject))

sql="Select case when to_char(sysdate,'D')=1 then to_char(sysdate-to_char(sysdate,'D')-5,'yyyy-mm-dd')  else to_char(sysdate-to_char(sysdate,'D')+2,'yyyy-mm-dd')  end  from dual";

else if("nextWeek".equals(anObject))

sql=" Select case when to_char(sysdate,'D')=1 then to_char(sysdate-to_char(sysdate,'D')+2,'yyyy-mm-dd') else to_char(sysdate-to_char(sysdate,'D')+9,'yyyy-mm-dd') end  from dual";

else if("lastWeek".equals(anObject))//上周

sql="Select case when to_char(sysdate,'D')=1 then to_char(sysdate - to_char(sysdate, 'D') -12,'yyyy-mm-dd') else to_char(sysdate - to_char(sysdate, 'D') -5,'yyyy-mm-dd')  end  from dual";

time=this.getToCharSysdateParameter(sql);

return time;

}

/**

*

* @param anObject:thisWeek=本周;nextWeek=下周;lastWeek=上周

* @return sunday

*/

public String getSunday(String anObject){

String sql="";

String time="";

if("thisWeek".equals(anObject))//本周

sql="Select to_char(sysdate,'D'),case when to_char(sysdate,'D')=1 then to_char(sysdate-to_char(sysdate,'D')+1,'yyyy-mm-dd') else to_char(sysdate-to_char(sysdate,'D')+8,'yyyy-mm-dd')  end  from dual";

else if("nextWeek".equals(anObject))//下周

sql="Select to_char(sysdate,'D'),case when to_char(sysdate,'D')=1 then to_char(sysdate-to_char(sysdate,'D')+8,'yyyy-mm-dd') else to_char(sysdate-to_char(sysdate,'D')+15,'yyyy-mm-dd')  end  from dual";

else if("lastWeek".equals(anObject))//上周

sql="Select case when to_char(sysdate,'D')=1 then to_char(sysdate - to_char(sysdate, 'D') -6,'yyyy-mm-dd') else to_char(sysdate - to_char(sysdate, 'D') +1,'yyyy-mm-dd')  end  from dual";

time=this.getToCharSysdateParameter(sql);

return time;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值