夜航星0619 2022-06-14 09:52 采纳率: 87.5%
浏览 124
已结题

Hive如何获取一周前分区的数据?

分区有三个字段,分别是int类型的year,month和day。
如果我想select查询一个星期之前的数据,如果day是8号以后,那么我可以直接${dd}-7。
select * from 表名 where year=${4个y} and month=${mm} and day=${dd}-7;(关于“4个y”这种写法我也不想这么写,但真写4个y系统会提示禁止重复输入同样的符号,通过不了审核)
但如果day是比7小的数字,直接用${dd}减就查询不到了。
这种情况下查询语句应该怎么写呢?

  • 写回答

1条回答 默认 最新

  • 魂落忘川犹在川 2022-06-14 10:02
    关注
    select date_sub('2022-06-02',7)
    select date_sub(concat_ws('-','2022','6','2'),7)
    select day(date_sub(concat_ws('-','2022','6','2'),7))
    select day(date_sub(concat_ws('-',year,month,day),7))
    七天前数据 :  date(concat_ws('-',year,month,day)) < date_sub(concat_ws('-',year,month,day),7)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 6月22日
  • 已采纳回答 6月14日
  • 创建了问题 6月14日

悬赏问题

  • ¥15 如何对参数分析结构进行绘图
  • ¥15 做一个满足376和698规约的集中器程序
  • ¥50 python如何用抖音这个接口输入抖音ID查询用户信息
  • ¥30 关于移动Web网页使用TinyMCE富文本编辑器上传图片后的光标定位、压缩等几个问题如何解决:
  • ¥40 activeMq在同服务器centos8下消费很慢
  • ¥20 为什么zynq CAN IP 无法进入config配置模式,XCan_SelfTest函数失效?
  • ¥15 Pycharm中程序直接运行可以但进入调试报错
  • ¥15 MATLAB动图问题
  • ¥15 有段代码不知道怎么理解,const isToken = (config.headers || {}).isToken === false
  • ¥15 我的显卡支持CUDA最高版本是12.3,这个版本也支持VS 2022 17.0这种情况下如果我想下载CUDA11.8,需要下载旧版本的VS2022吗