Hql取上周、上月、上季度、去年第一天和最后一天

上周一:

select date_sub(current_date(),pmod(datediff(cast(current_date() as string),'2000-01-03'),7)+7)

上周日:

select date_sub(current_date(),pmod(datediff(cast(current_date() as string),'2000-01-03'),7)+1)

上月第一天:

select  add_months(trunc(current_date(),'MM'),-1)

上月最后一天:

 select  date_add(trunc(current_date(),'MM'),-1)

上季度第一天 :

select to_date(concat(date_format(current_date(),'y'),'-',floor((cast(date_format(add_months(current_date(),-3),'M') as int)+2)/3)*3-2,'-',date_format(trunc(current_date(),'MM'),'dd')))

上季度最后一天 :

select last_day(to_date(concat(date_format(current_date(),'y'),'-',floor((cast(date_format(add_months(current_date(),-3),'M') as int)+2)/3)*3,'-','01')))

去年第一天 :

select  add_months(trunc(current_date(),'YY'),-12)

去年最后一天 :

select date_add(trunc(current_date(),'YY'),-1)
要在HQL中实现每月天数据除以上一个月最后一天的数据,可以利用日期函数结合窗口函数或者聚合查询完成此操作。下面是一个大致思路: 1. **提月份**:通过 `month()` 函数获取记录所属的月份。 2. **找到上个月最后一天的数据**:可以通过将当前月减去一个月,并结合 `last_day()` 函数定位到上个月的最后一天。 3. **计算比率**:将当月每一天的数据与上一月底的数据相除。 ### 示例 HQL 查询 ```sql WITH MonthlyData AS ( SELECT date_column, value_column, month(date_column) AS current_month, year(date_column) AS current_year, last_day(add_months(date_column, -1)) AS prev_month_last_date -- 找到上个月的最后一天 FROM your_table_name ), PrevMonthLastValue AS ( SELECT date_column, value_column AS prev_value FROM your_table_name WHERE day(date_column) = day(last_day(date_column)) ) SELECT m.date_column, m.value_column / p.prev_value AS ratio FROM MonthlyData m LEFT JOIN PrevMonthLastValue p ON m.prev_month_last_date = p.date_column; ``` #### 解释: - 首先创建了一个临时表 (`MonthlyData`) 来存储每个月对应的上个月最后一天。 - 然后从原表中筛选出所有代表“上个月最后一天”的行作为另一个临时表 (`PrevMonthLastValue`)。 - 最终通过左连接匹配每条日数据它对应上个月最后一天的数据并计算比率。 请注意这只是一个示例框架,实际应用需要依据数据库设计调整字段名、表结构等细节内容。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值