ORACLE日期相关语法

一、日期格式

1.1 日期格式
  1. YYYY-MM-DD 年-月-日
  2. HH24:MI:SS 时:分:秒(HH12、HH : 均为 12 小时制 )
sql 复制代码
select to_char(sysdate, 'YYYY-MM-DD HH24:MI:SS') 当前时间 from dual;
1.2 注意:一周的第一天是周日
1.3 日期展示示例
sql 复制代码
SELECT SYSDATE 当前时间,
       trunc(SYSDATE) 今日0点,
       trunc(SYSDATE) + 6 / 24 当天6点,
       to_char(SYSDATE, 'YYYY') 四位年,
       to_char(SYSDATE, 'YY') 两位年,
       to_char(SYSDATE, 'MM') 月份,
       to_char(SYSDATE, 'MONTH') 月份带月份名,
       to_char(SYSDATE, 'MON') 月份带月份名简称,
       to_char(SYSDATE, 'RM') 月份罗马数字,
       to_char(SYSDATE, 'DDD') 当年第n天,
       to_char(SYSDATE, 'DD') 当月第n天,
       to_char(SYSDATE, 'D') 当周第n天,
       to_char(SYSDATE, 'DY') 星期几,
       to_char(SYSDATE, 'Q') 当年第n季度,
       to_char(SYSDATE, 'WW') 当年第n周,
       to_char(SYSDATE, 'W') 本月第n周,
       to_char(SYSDATE, 'HH24') 24小时制,
       to_char(SYSDATE, 'HH12') 12小时制
  FROM dual;

二、常用日期函数

2.1 字符串转换为日期:to_date()
sql 复制代码
select to_date('2023-11-07 16:35:33', 'yyyy-mm-dd hh24:mi:ss') result from dual;
2.2 返回特定日期月份的最后一天:last_day()
SQL 复制代码
select last_day(sysdate) from dual;
2.3 增加或减去月份:add_months()
sql 复制代码
-- 增加一个月
select add_months(sysdate, 1) result from dual;
-- 减少一个月
select add_months(sysdate, -1) result from dual;
-- 前一天
select sysdate - 1 from dual;
-- 后一天
select sysdate + 1 from dual;
2.4 比较两个时间的月份差:months_between(date1, date2)
sql 复制代码
select months_between(sysdate, to_date('2023-02-22', 'yyyy-mm-dd')) from dual;

三、项目实例

3.1 加减时间
sql 复制代码
SELECT SYSDATE "当前时间",
       SYSDATE + 1 "加一天",
       SYSDATE - 1 "减一天",
       SYSDATE + (1 / 24) "加一小时",
       SYSDATE + (1 / 24 / 60) "加一分钟",
       SYSDATE + (1 / 24 / 60 / 60) "加一秒钟"
  FROM dual;
3.2 判断当前时间为星期几、几月份、年份
sql 复制代码
-- 判断周几:每周的第一天为星期天,星期一为第二天,所以要减一
SELECT to_char(SYSDATE, 'D') - 1 FROM dual; 
-- 直接输出今日周几
SELECT to_char(sysdate, 'day') FROM dual; 
-- 判断特定日期是星期几
select to_char(to_date('2023-11-11', 'YYYY-MM-DD'), 'DY') from dual;
-- 输出特定日期的月份、年份
SELECT to_char(to_date('2023-11-11', 'YYYY-MM-DD'), 'MM') 当前月份,
       to_char(to_date('2023-11-11', 'YYYY-MM-DD'), 'YYYY') 当前年份
  FROM dual;
SELECT trunc(SYSDATE, 'DD') 今天的开始,
       trunc(SYSDATE, 'iw') 这周的第一天,
       trunc(SYSDATE, 'MM') 这个月的第一天,
       trunc(SYSDATE, 'q') 这个季度的第一天,
       trunc(SYSDATE, 'YYYY') 今年第一天,
       extract(day from last_day(sysdate)) 当月天数
  FROM dual; 
3.3 两个时间的时间差
sql 复制代码
SELECT TIME 具体相差时间,
       floor(TIME) 相差天数,
       CASE
         WHEN TIME < 1 THEN
          trunc(TIME * 24)
         WHEN TIME > 1 THEN
          MOD(trunc(TIME * 24), 24)
         ELSE
          0
       END AS 小时差,
       trunc(TIME * 24 * 60 - 60 * trunc(TIME * 24)) 分钟差,
       trunc(TIME * 24 * 60 * 60 - 60 * trunc(TIME * 24 * 60)) 秒差
  FROM (SELECT to_number(SYSDATE - to_date('1999-02-22 20:20:20', 'YYYY-MM-DD hh24:mi:ss')) AS TIME
          FROM dual)
3.4 判断当前时间是今年的那一天
sql 复制代码
SELECT to_char(SYSDATE, 'D') - 1 本周第几天,
       to_char(SYSDATE, 'DD') 本月第几天,
       to_char(SYSDATE, 'DDD') 本年第几天
  FROM dual;
相关推荐
CC大煊9 分钟前
【java】Druid数据库连接池完整配置指南:从入门到生产环境优化
java·数据库·springboot
学Linux的语莫16 分钟前
mysql主从同步(复制)搭建
数据库·mysql
SelectDB22 分钟前
慢 SQL 诊断准确率 99.99%,天翼云基于 Apache Doris MCP 的 AI 智能运维实践
数据库·人工智能·apache
JIngJaneIL23 分钟前
基于java+ vue交友系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·交友
数据知道1 小时前
为什么要用向量数据库?常用的向量数据库有哪些以及如何选择?
数据库·向量数据库
dixiuapp1 小时前
设备维修记录系统,从数据沉淀到价值挖掘的跃迁
大数据·数据库·人工智能
问道飞鱼2 小时前
【数据库知识】MySQL 多表关联高效实现指南:场景化方案与底层原理
数据库·mysql·多表关联
马克学长2 小时前
SSM校园二手交易平台7fut7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·校园闲置资源交易
dblens 数据库管理和开发工具2 小时前
MySQL :5.7与8.0版创建用户与授权、密码认证插件、角色、密码过期策略
数据库·mysql·dblens·mysql创建用户·mysql设置密码·mysql用户授权
曹牧2 小时前
Oracle:字段为值列表
数据库·oracle