oracle 操作时间的函数总结
【摘要】 下面是一些使用 Oracle 数据库中处理时间的函数的 SQL 查询示例:SYSDATE - 获取当前日期和时间:SELECT SYSDATE FROM dual;CURRENT_DATE - 获取当前日期:SELECT CURRENT_DATE FROM dual;SYSTIMESTAMP - 获取当前日期和时间及时区信息:SELECT SYSTIMESTAMP FROM dual;CUR...
下面是一些使用 Oracle 数据库中处理时间的函数的 SQL 查询示例:
- SYSDATE - 获取当前日期和时间:
SELECT SYSDATE FROM dual;

- CURRENT_DATE - 获取当前日期:
SELECT CURRENT_DATE FROM dual;

- SYSTIMESTAMP - 获取当前日期和时间及时区信息:
SELECT SYSTIMESTAMP FROM dual;

- CURRENT_TIMESTAMP - 获取当前日期和时间及时区信息:
SELECT CURRENT_TIMESTAMP FROM dual;

可以看出
- SYSDATE 和 CURRENT_DATE 输出的值都是一样的
- SYSTIMESTAMP 和 CURRENT_TIMESTAMP 输出的值都是一样的
- SYSTIMESTAMP 比起 SYSDATE 会额外输出毫秒值和时区,其他一样
- CURRENT_TIMESTAMP 比起 CURRENT_DATE 会额外输出毫秒值和时区,其他一样
SELECT SYSDATE, CURRENT_DATE, SYSTIMESTAMP, CURRENT_TIMESTAMP FROM DUAL

- EXTRACT - 提取日期/时间的一部分:
例如通过EXTRACT 函数提取年、月、日
SELECT SYSDATE, EXTRACT(YEAR FROM SYSDATE), EXTRACT(MONTH FROM SYSDATE), EXTRACT(DAY FROM SYSDATE) FROM DUAL

例如通过EXTRACT 函数提取时、分、秒
注意:
- 获取时分秒,不能用SYSDATE,只能用SYSTIMESTAMP
- 获取时分秒,不能用CURRENT_DATE,只能用CURRENT_TIMESTAMP
SELECT SYSTIMESTAMP, EXTRACT(HOUR FROM SYSTIMESTAMP), EXTRACT(minute from SYSTIMESTAMP), EXTRACT(second from SYSTIMESTAMP) FROM DUAL

- ADD_MONTHS - 向日期添加指定月数:
SELECT ADD_MONTHS(SYSDATE, 3) AS ThreeMonthsLater FROM dual;

- MONTHS_BETWEEN - 计算两个日期之间的月数差:
注意:这里只有 MONTHS_BETWEEN 有效。YEARS_BETWEEN 和 DAYS_BETWEEN 这两个都是无效函数
SELECT MONTHS_BETWEEN(SYSDATE, TO_DATE('2023-01-01', 'YYYY-MM-DD')) AS MonthsDifference FROM dual;

- NEXT_DAY - 获取下一个指定星期几的日期:
SELECT SYSDATE,
NEXT_DAY(SYSDATE, 1) AS n1,
NEXT_DAY(SYSDATE, 2) AS n2,
NEXT_DAY(SYSDATE, 3) AS n3,
NEXT_DAY(SYSDATE, 4) AS n4,
NEXT_DAY(SYSDATE, 5) AS n5,
NEXT_DAY(SYSDATE, 6) AS n6,
NEXT_DAY(SYSDATE, 7) AS n7
FROM DUAL

- LAST_DAY - 获取月份的最后一天:
SELECT LAST_DAY(SYSDATE) AS LastDayOfMonth FROM dual;

- ROUND - 对日期进行四舍五入:
SELECT SYSDATE, ROUND(SYSDATE, 'MONTH'), ROUND(TO_DATE('2024-04-10 20:12:30', 'YYYY-MM-DD HH24:MI:SS'), 'MONTH') FROM DUAL;

- TRUNC - 截断日期到指定精度:
SELECT TRUNC(SYSDATE, 'YY'), TRUNC(SYSDATE, 'MM'), TRUNC(SYSDATE, 'HH'), TRUNC(SYSDATE, 'mi') FROM DUAL;
注意:TRUNC 可以截取到 年、月、日、时、分,但是没有秒

- TO_CHAR - 将日期/时间转换为字符串:
SELECT TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS') AS FormattedDate FROM DUAL;

- TO_DATE - 将字符串转换为日期:
SELECT TO_DATE('2024-04-20', 'YYYY-MM-DD') AS DateFromString FROM DUAL;

- TO_TIMESTAMP - 将字符串转换为时间戳:
SELECT TO_TIMESTAMP('2024-04-20 12:34:56', 'YYYY-MM-DD HH24:MI:SS') AS TimestampFromString FROM DUAL;

TO_DATE 和 TO_TIMESTAMP 效果是一样的
SELECT TO_DATE('2024-04-20 12:34:56', 'YYYY-MM-DD HH24:MI:SS') AS DateFmt,
TO_TIMESTAMP('2024-04-20 12:34:56', 'YYYY-MM-DD HH24:MI:SS') AS TimestampFmt
FROM DUAL;

- NEW_TIME - 将一个时区的时间转换为另一个时区的时间:
SELECT NEW_TIME(SYSDATE, 'AST', 'PST') AS ConvertedTime FROM DUAL;

所有的时区如下

【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)