oracle中如何查询特定日期?

select last_day(to_date('20230101','YYYYMMDD')) from dual;

select last_day(to_date(V_END_DATE,'YYYYMMDD')) from dual; --查询任意一天 当月的最后一天

select to_char(to_date('20230101','YYYYMMDD')-1,'YYYYMMDD') INTO V_START_DATE FROM DUAL;

select to_char(to_date(V_END_DATE,'YYYYMMDD')-1,'YYYYMMDD') INTO V_START_DATE FROM DUAL; --查询任意一天的前一天

--字符型转日期型 -1 之后再转字符型

select to_char(last_day(add_months(SYSDATE, -2)) + 1,'yyyymmdd') First_DayOfMonth from dual; --查询上一个月第一天

select to_char(last_day(add_months(SYSDATE, -1)),'yyyymmdd') Last_DayOfMonth from dual; --查询上一个月最后一天

select to_number(add_months(trunc(to_date(V_FIRST_DAY,'yyyymmdd'), 'mm'), 1) - trunc(to_date(V_FIRST_DAY,'yyyymmdd'), 'mm')) into from dual; --指定月份天数,V_FIRST_DAY为那个月份任意一天

查询指定月份/年份/日期的第一天和最后一天

SELECT TO_CHAR(TRUNC(TO_DATE('2018-06','YYYY-MM'), 'MM'), 'YYYY-MM-DD') "指定日期第一天" FROM DUAL;

SELECT TO_CHAR(LAST_DAY(TO_DATE('2018-06','YYYY-MM')), 'YYYY-MM-DD') "指定日期最后一天" FROM DUAL;

--年

select trunc(sysdate, 'yy') "当年第一天" from dual;

select trunc(sysdate, 'yyyy') "当年第一天" from dual;

select trunc(sysdate, 'year') "当年第一天" from dual;

--季度

select trunc(sysdate, 'q') "当前季度的第一天" from dual;

select trunc(add_months(sysdate,3), 'Q') -1/24 "这个季度最后一天23点" from dual;

--月

select trunc(sysdate, 'mm') "当月第一天" from dual;

select trunc(sysdate, 'month') "当月第一天" from dual;

select trunc(last_day(sysdate)+1) "下个月第一天的0点" from dual;

--周

select trunc(sysdate, 'd') "本周的第一天,周日起" from dual;

select trunc(sysdate,'day') "本周的第一天,周日起" from dual;

select next_day(TRUNC(SYSDATE ), 'TUESDAY' ) + 12/24 "下个星期二中午12点" from dual;

select TRUNC(LEAST(NEXT_DAY(SYSDATE, 'SATURDAY'), NEXT_DAY(SYSDATE, 'SUNDAY'))) + (6*60+10)/(24*60) "下个周六日早上6点10分" from dual;

--天

select trunc(sysdate+1) "今晚12点" from dual;

select trunc(sysdate+1) + (8*60+30)/(24*60) "明天早上8点30分" from dual;

--时

select trunc(sysdate, 'hh')"当前小时" from dual;

select trunc(sysdate, 'hh24') "当前小时" from dual;

--分

select trunc(sysdate, 'mi') "当前分钟" from dual;

select trunc(sysdate,'mi') + 10/ (24*60) "10分钟后的时间"from dual;

--秒

select sysdate + 10/(24 * 60 * 60) "10秒钟后" from dual;--trunc没有精确到秒的精度

相关推荐
数据仓库_晨曦3 分钟前
【无标题】
大数据·sql·spark
anew___4 分钟前
《数据库原理》精要解读(三)—— SQL:与数据库对话的艺术
数据库·sql·oracle
KaiwuDB4 分钟前
KWDB 3.2.0 版本发布,数据管理查询增强,安装部署体验全面升级
数据库
暴躁小师兄数据学院11 分钟前
【AI大数据工程师特训笔记】第10讲:数据库用户、权限管理、数据库约束
大数据·数据库·笔记·sql·postgresql
凤山老林22 分钟前
DDD(领域驱动设计)在复杂业务系统中的落地指南
java·开发语言·数据库·ddd·领域驱动
凯瑟琳.奥古斯特33 分钟前
子查询原理与实战案例解析
开发语言·数据库·职场和发展·数据库开发
KaMeidebaby1 小时前
卡梅德生物技术快报|酵母双杂交 cDNA 文库构建与蛋白互作筛选流程
服务器·前端·数据库·人工智能·算法
暴躁小师兄数据学院1 小时前
【AI大数据工程师特训笔记】第02讲:PostgreSQL数据库生态全景
大数据·数据库·人工智能·postgresql
沐风___1 小时前
App 上架之后:如何看数据、获取用户与持续迭代产品
服务器·前端·数据库
兔子宇航员03011 小时前
HIVE SQL 中 NULL 值在 JOIN 和 GROUP BY 中的致命陷阱与解决方案
hive·hadoop·sql