oracle 取日期 加天,oracle日期,获取年月日等函数、日期函数、时区

本文介绍了如何在Oracle数据库中使用SQL进行日期选择、格式化、获取月日、获取特定月份天数,以及设置和查看时区的方法。还涵盖了时间转换和错误处理,如TO_DATE函数的使用和时区设置技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

7ff4752c654b50b75612d7333668e670.png

月 select extract(month from sysdate) from dual;

日 select extract(day from sysdate) from dual;

格式化日期:

TO_CHAR(SYSDATE(),"YY/MM/DD HH24:MI:SS)

或 TO_DATE(SYSDATE(),"YY/MM/DD HH24:MI:SS)

select to_char(sysdate,"yyyy-MM-dd HH24:mi:ss") from dual;

select to_char(sysdate,"yyyy-MM-dd HH24:mm:ss") from dual;

select to_char(sysdate,"yy-mm-dd hh24:mi:ss") from dual

select to_date("2018-07-25 15:53:13","yyyy-mm-dd,hh24:mi:ss") from dual

如果把上式写成下面形式则会报错,因为小时hh是12进制。

select to_date("2018-07-25 15:54:34","yyyy-mm-dd,hh:mi:ss") from dual

获取某月天数

select to_char(last_day(to_date("2010-11-1","YYYY-MM-DD")),"DD") from dual;

oracle 10g修改默认的日期格式:

alter session set nls_date_format ="yyyy-mm-dd";

alter session set nls_date_format = "yyyy-mm-dd hh24:mi:ss";

oracle时区

Oracle 的时区可以分为两种,一种是数据库的时区,一种是 session 时区,也就是客户端连接时的时区(经过实验,连接以后再修改客户端的时区,session 的时区不会更改)。

数据库的时区在创建数据库时可以通过在 create database 语句中加上SET TIME_ZONE = " { { + | - } hh : mi | time_zone_region } " 来指定,如果,不指定,默认是按照数据库所在的操作系统时区来设定的。

查看各种时间:

select sysdate,CURRENT_DATE,CURRENT_TIMESTAMP,LOCALTIMESTAMP from dual

查看时区:

select dbtimezone from dual;--数据库时区

select sessiontimezone from dual;--session时区

修改时区:

(东八区)

alter database set time_zone="+08:00";--东八区

ALTER SESSION SET TIME_ZONE = "Australia/Sydney";--修改session时区

ALTER SESSION SET TIME_ZONE = "Chile/EasterIsland";--修改session时区

ALTER SESSION SET TIME_ZONE="+08:00";--修改session时区

查询时区差时

TZ_OFFSET ( { "time_zone_name"

| "{ + | - } hh : mi"

| SESSIONTIMEZONE

| DBTMEZONE }

)

SELECT TZ_OFFSET("US/Eastern") FROM DUAL;

SELECT TZ_OFFSET(DBTIMEZONE) FROM DUAL;

TO_DATE(sysdate,"yyyy-mm-dd")方法转换时间格式时会报错,文字与字符串格式不匹配,

可以改成TO_CHAR(sysdate,"yyyy-mm-dd")

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值