分区有三个字段,分别是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 02: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)
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用