oracle系统函数(日期函数)
oracle系统函数(日期函数)
调用日期函数时,首先要明确两个概念,时间戳和日期是不同的,日期中包括年月日但不包括小时分钟秒,时间戳包括年月日小时分钟秒。在oracle中,一般情况下,函数中包含date字符的和日期有关,包含timestamp的函数和时间戳有关(时间戳可以理解为时间)。oracle中,日期一般以天为基本单位,时间相减时结果单位为天,时间与数字相加时,默认加对应数字的天数。
一、调用时无参无括号时间函数
1.返回系统当前日期sysdate
--该函数返回值没有时间戳
select sysdate from dual;
2.返回会话中的日期和时间localtimestamp
--不包括时区
select localtimestamp from dual;
3.返回会话时区中的当前日期和时间current_timestamp
--包括时区
select current_timestamp from dual;
4.返回当前会话时区中的当前日期current_date
select current_date from dual;
5.返回数据库时区设置dbtimezone
select dbtimezone from dual;
6.返回当前会话时区sessiontimezone
select sessiontimezone from dual;
7.变动日期时间数值interval
--设置数值代表秒,分,小时,天,月,年
例如:
interval '1' second 1秒
interval '1' minute 1分
interval '1' hour 1小时
interval '1' day 1天(系统默认)
interval '1' month 1月
interval '1' year 1年
select trunc(sysdate)+(interval '' second),--加1s
trunc(sysdate)+(interval '' hour),--加1个小时
trunc(sysdate)+(interval '' day),--加1天
trunc(sysdate)+1--加1天
from dual;
二、调用时有括号的日期函数
1.返回指定月数后的日期add_months()
select add_months(sysdate,3) from dual;
等价于
select trunc(sysdate)+interval '' month from dual;
2.返回本月最后一天的日期last_day()
select last_day(sysdate) from dual;
返回本月第一天
select trunc(sysdate,'month') from dual;
3.返回2个日期间隔月数month_between()
select months_between(sysdate,to_date('2015-09-01','YYYY-MM-DD'))
from dual;
4.四舍五入后的期间第一天round()
select sysdate,
round(sysdate),--最近0点日期
round(sysdate,'day'),--最近星期日
round(sysdate,'month'),--最近月初
round(sysdate,'q'),--最近季出日期
round(sysdate,'year')--最近年初日期
from dual;
5.返回日期所在期间的第一天trunc()
select trunc(sysdate),--今天日期
trunc(sysdate,'day'),--本周星期日,等价于trunc(sysdate,'D')和trunc(sysdate,'d')
trunc(sysdate,'month'),--本月初,若trunc(sysdate,'M')和trunc(sysdate,'m')则执行出错
trunc(sysdate,'q'),--本季初日期
trunc(sysdate,'year')--本年初日期,等价于trunc(sysdate,'Y')和trunc(sysdate,'y')
from dual;
6.返回下周某一天的日期next_day(),可以返回下周的周一到周日
select sysdate,
next_day(sysdate,'星期一'),--返回下周星期一
next_day(sysdate,'星期二')--返回下周星期二
from dual;
7.提取时间日期中数据extract()
--提取小时,分钟,秒时需要加上timestamp
select
extract(minute from timestamp '2015-2-16 2:38:40'),--timestamp时间戳
extract(hour from timestamp '2015-2-16 2:38:40'),
--extract(hour from timestamp(sysdate)),错误
extract(hour from localtimestamp),--返回值错误
extract(hour from current_timestamp),
extract(day from sysdate),--日
extract(month from sysdate),
extract(year from sysdate)
from dual;
总结:关于日期的函数还是挺多的,但是常用的一般为sysdate,localtimestramp,trunc,interval和extract,重点掌握这些应该足够了,其他不常用的可以用的时候再查找。
oracle系统函数(日期函数)的更多相关文章
- javascript函数一共可分为五类: ·常规函数 ·数组函数 ·日期函数 ·数学函数 ·字符串函数
javascript函数一共可分为五类: ·常规函数 ·数组函数 ·日期函数 ·数学函数 ·字符串函数 1.常规函数 javascript常规函数包括以下9个 ...
- 第17课-数据库开发及ado.net 聚合函数,模糊查询like,通配符.空值处理.order by排序.分组group by-having.类型转换-cast,Convert.union all; Select 列 into 新表;字符串函数;日期函数
第17课-数据库开发及ado.net 聚合函数,模糊查询like,通配符.空值处理.order by排序.分组group by-having.类型转换-cast,Convert.union all; ...
- Oracle函数——日期函数
Oracle中的时间类型只有date和TIMESTAMP,TIMESTAMP是比date更精确的类型.日期时间函数用于处理时间类型的数据,Oracle以7位数字格式来存放日期数据,包括世纪.年.月.日 ...
- Oracle数据库之日期函数
今天给大家介绍一下oracle数据中的日期函数的用法.废话不多说,我们看一下oracle给我们提供了那些函数? 1.sysdate 用途:获取当前系统时间. 2.to_date('字符类型','日期类 ...
- Oracle之单行函数(字符串函数/数字函数/转换函数/日期函数/通用函数)
虚拟表DUAL介绍: dual是一张虚拟表,只有一行一列,用来构成select的语法规则. Oracle的查询中,必须使用"select 列- from 表"的完整语法,当查询单行 ...
- SQL 标量函数-----日期函数 day() 、month()、year()
select day(createtime) from life_unite_product --取时间字段的天值 select month(createtime) from life_unite_p ...
- SQL标量函数-日期函数
select day(createtime) from life_unite_product --取时间字段的天值 select month(createtime) from life_uni ...
- MySQL 进阶4 SQL常见函数: 字符函数/数学函数/日期函数/流程控制函数(if/case)
# 进阶4 SQL常见函数 分类: 1/单行函数: 字符函数: concat(),length(),ifnull(__,default) ,instr(), trim(),upper(),lower( ...
- SQL 标量函数-----日期函数 day() 、month()、year() 转载
select day(createtime) from life_unite_product --取时间字段的天值 select month(createtime) from life_u ...
- SQL 标量函数-----日期函数datediff()、 day() 、month()、year()
select day(createtime) from life_unite_product --取时间字段的天值 select month(createtime) from life_uni ...
随机推荐
- Linux 下安装 jdk-7u75-linux-x64.gz,jdk1.7.0_75,jdk1.7步骤:
摘要:近来又用到了Linux系统,所以就又新装了一个虚拟机和CentOS 6.4来用,搞开发的程序猿们可能都知道,在现在的很多企业中,生产环境大多都是Linux服务器,并且用的比较多的大都是CentO ...
- 包--R In Action
1.4 包R提供了大量开箱即用的功能,但它最激动人心的一部分功能是通过可选模块的下载和安装来实现的.目前有2500多个①称为包(package)的用户贡献模块可从http://cran.r-proje ...
- 关于js序列化时间的方法
var time = new Date(); var otime = getMyDate(time); //将毫秒转换成 年月日+时分秒 格式的 (1970-01-11 00:00:00) funct ...
- python--基本代码规范
python代码规范:一.标识符 所谓的标识符就是对变量.常量.函数.类等对象起的名字 python语言在任何场景都严格区分大小写!!! python对于标识符的命名有如下规定: 第一个字符必须是字母 ...
- 计算机_软件技巧_01_优雅地再word中插入代码
二.参考资料 1.如何优雅的在 Microsoft word中插入代码
- 条款51:编写new以及delete的时候需要固守常规
C++中delete一个指针之后,只是回收指针指向位置的空间,而指针本身的值不变.你需要手工将其赋值为NULL.注意的一点是delete NULL指针的时候不会有任何的事情发生 小结: o ...
- BZOJ - 2588 Spoj 10628. Count on a tree (可持久化线段树+LCA/树链剖分)
题目链接 第一种方法,dfs序上建可持久化线段树,然后询问的时候把两点之间的所有树链扒出来做差. #include<bits/stdc++.h> using namespace std; ...
- Spring转账业务_XML配置事物控制
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...
- Redis底层探秘(三):字典
字典,又称为符号表(symbol table).关联数组(associative array)或映射(map),是一种用于保存键值对的抽象数据结构. 字典经常作为一种数据结构内置在很多高级编程语言里面 ...
- The Sum of 0 for four numbers(拆解加二分思想)
个人心得:单纯用二分法一直超时,后面发现我的那种方法并没有节省多少时间,后面看了大神的代码,真的是巧妙, 俩个数组分别装a+b,c+d.双指针一个指向最后,从第一个开始想加,加到刚好大于0停止,再看是 ...