欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Oracle中时间相关函数

程序员文章站 2024-01-23 16:14:58
...

1、to_char()函数:可以将日期按照一定格式转换为字符串类型

获取时间的日 

select to_char(sysdate,'dd') as nowDay from dual;

2、trunc()函数

trunc()函数两种用法,截断数字或者是截断日期。

2.1.截断数字:格式:TRUNC(n1,n2),n1表示被截断的数字,n2表示要截断到那一位。n2可以是负数,表示截断小数点前。注意,TRUNC截断不是四舍五入。

2.2.截断日期:

截取今天

select sysdate,trunc(sysdate,'dd') from dual

截取本周第一天

select sysdate,trunc(sysdate,'d') from dual

截取本月第一天

select sysdate,trunc(sysdate,'mm') from dual

截取本年第一天

select sysdate,trunc(sysdate,'y') from dual

3、add_months()函数

add_month(n1,n2),n1表示日期格式数据,n2表示对日期加减的数字(以月为单位)

获取上个月的今天

select add_months(sysdate,-1) from dual

4、last_day()函数

last_day()函数返回指定日期对应月份的最后一天

获取当前日期的最后一天

SELECT last_day(SYSDATE) FROM dual

5、获取某个日期的当前所在月第一天和最后一天

select trunc(to_date('2020-10-12','yyyy/mm/dd'),'mm') as firstDay,
last_day(to_date('2020-10-13','yyyy/mm/dd')) as lastDay 
from dual; 
--查询表中日期在2020/10/1~2020/10/31(假设是给定随机的时间)之间的数据 
select bid from book 
where tyrq between 
    trunc(to_date('2020-10-12','yyyy/mm/dd'),'mm') 
and 
    last_day(to_date('2020-10-13','yyyy/mm/dd'));

6、获取某个日期所在月的上个月的第一天和最后一天

--第一种写法:
select
trunc(add_months(to_date('某个日期','yyyy-mm-dd'),-1),'mm') as firstDay,
last_day(add_months(to_date('某个日期','yyyy/mm/dd'),-1)) as lastDay
from dual;

----------------------------------------------------------------------

--第二种写法:
select 
add_months(trunc(to_date('某个日期','yyyy/mm.dd'),'mm'),-1) as firstDay,
add_months(last_day(to_date('某个日期','yyyy/mm/dd')),-1) as lastDay
from dual;

查询表中时间在某个时间上个月范围内的数据 :

--第一种写法:
select bid from book 
where tyrq between 
    trunc(add_months(to_date('某个日期','yyyy-mm-dd'),-1),'mm') 
and 
    last_day(add_months(to_date('某个日期','yyyy/mm/dd'),-1))

--------------------------------------------------------------------

--第二种写法:
select bid from book 
where tyrq between 
    add_months(trunc(to_date('某个日期','yyyy/mm.dd'),'mm'),-1) 
and 
    add_months(last_day(to_date('某个日期','yyyy/mm/dd')),-1)
相关标签: Oracle 数据库