oracle 获取 年,月,周 数据

本文介绍了如何使用Oracle SQL查询当月、当年和本周的数据。对于当月数据,通过比较创建时间与当前月的第一天和最后一天来筛选;当年数据则基于当前年的开始和结束日期;对于国外以周日为一周第一天的情况,查询本周数据从周日后的第一天到周六;而在国内,以周一为一周开始,则查询从上周一到本周日的数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当月数据

Sql代码
  1. select * from table t   
  2. where t.create_time >=TRUNC(SYSDATE, 'MM')   
  3. and t.create_time<=last_day(SYSDATE)  
select * from table t
where t.create_time >=TRUNC(SYSDATE, 'MM')
and t.create_time<=last_day(SYSDATE)


当年数据

Sql代码
  1. select * from table t   
  2. where t.create_time >=trunc(sysdate,'YYYY')   
  3. and t.create_time<=add_months(trunc(sysdate,'YYYY'),12)-1  
select * from table t
where t.create_time >=trunc(sysdate,'YYYY')
and t.create_time<=add_months(trunc(sysdate,'YYYY'),12)-1


本周(国外周日为一个星期第一天)

Sql代码
  1. where t.create_time >=trunc(sysdate,'day')+1 and t.create_time<=trunc(sysdate,'day')+6   
where t.create_time >=trunc(sysdate,'day')+1 and t.create_time<=trunc(sysdate,'day')+6


本周(国内周一为一个星期第一天)

Sql代码
  1. where t.create_time >=trunc(next_day(sysdate-8,1)+1) and t.create_time<=trunc(next_day(sysdate-8,1)+7)+1  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值