Oracle关于时间/日期的操作
6.计算程序运行的时间(ms)
返回由fmt指定的单位的日期d.
----------
----------------------------------------
返回d1和d2之间月的数目,如果d1和d2的日的日期都相同,或者都使该月的最后一天,那么将返回一个整数,否则会返回的结果将包含一个分数。
19、convert(,[,])
select test_id from test_case where rowid=chartorwid(''aaaa0saacaaaaliaaa'')
c表示字符串,fmt表示一种特殊格式的字符串。返回按照fmt格式显示的c,nlsparm表示使用的语言。函数将字符串c转换成date数据类型。
'select object_name from all_objects '||
18、chartorwid()
c 使一个字符串,函数将c转换为rwid数据类型。
13-11月-03 12.09.31.006000 13-11月-03 12.09.31.006000 下午 +08:
5.oracle有毫秒级的数据类型
Next Year
单行日期函数
SQL>
d1是一个日期数据类型,当时区tz1中的日期和时间是d时,返回时区tz2中的日期和时间。tz1和tz2时字符串。
Last Year
10、add_months(,)
11
--------------- ----------
23、to_char([[,)
date_value:=add_months(date_value,number_of_months)
close l_rc;
27、to_single_byte()
SQL> column sessiontimezone for a15
----------
-11:00 12-11月-03 04.59.13.668000 下午 -11:
说明:
25、to_multi_byte()
22、rowidtochar()
34.4035409
SQL> select add_months(sysdate,12) "Next Year" from dual;
29-2月 -00
当前时间减去7月的时间
SQL>
x是一个data或number数据类型,函数将x转换成fmt指定格式的char数据类型,如果x为日期nlsparm=nls_date_language 控制返回的月份和日份所使用的语言。如果x为数字nlsparm=nls_numeric_characters 用来指定小数位和千分位的分隔符,以及货币符号。
select next_day(''01-jan-2000'',''monday'') "1st monday",next_day(''01-nov-2004'',''tuesday'')+7 "2nd tuesday") from dual;1st monday 2nd tuesday03-jan-2000 09-nov-2004
'where object_id = ' || i;
timestamp_with_time_zone_value:=current_timestamp([timestamp_precision])
date_value:=last_day(date_value)
--返回当前 时间的秒毫秒,可以指定秒后面的精度(最大=9)
--------------- ------------------------------------
+08:00 13-11月-03
SESSIONTIMEZONE CURRENT_TIMESTAMP
SQL>
会话已更改。
l_dummy all_objects.object_name%type;
2006
SQL> select dbtimezone from dual;
dbms_output.put_line
select to_date('2003-10-17 21:15:37','yyyy-mm-dd hh24:mi:ss') from dual
-----------
----------
date_value:=current_date
varchar_value:=dbtimezone
00
x为16进制的字符串,函数将16进制的x转换为raw数据类型。
select sysdate,to_char(sysdate,'yyyy-mm-dd hh:mi:ss') from dual
SQL> select localtimestamp,current_timestamp from dual;
SESSIONTIMEZONE CURRENT_TIMESTAMP
open l_rc for
SQL>
例:
declare
MONTHS_BETWEEN(SYSDATE,DATE'1971-05-18')
SQL> select sessiontimezone,current_timestamp from dual;
l_rc rc;
DBTIME
' seconds...' );
SQL> select months_between(sysdate,date'1971-05-18') from dual;
会话已更改。
---------------------------- ------------------------------------
20、hextoraw()
单行转换函数用于操作多数据类型,在数据类型之间进行转换。
end;
3、current_timestamp()以timestamp with time zone数据类型返回当前会放时区中的当前日期
SQL>
21、rawtohex()
将日期d按照fmt指定的格式舍入,fmt为字符串。
SQL> alter session set time_zone='-11:00'
3. 字符到日期操作
下午
26、to_number([,[,)
SQL>
17、trunc([,])
fetch l_rc into l_dummy;
number_value:=months_between(date_value,date_value)
SQL> column localtimestamp format a28
( round( (dbms_utility.get_time-l_start)/100, 2 ) ||
c表示一个字符串,函数将c的担子截字符转换成多字节字符。
---------------------------- ------------------------
end loop;
12-11月-03 05.11.31.259000 13-11-2003 12:11:31 下午
Leap Yr?
SQL> alter session set time_zone='-11:00'
7、localtimestamp()返回会话中的日期和时间
SQL> select sessiontimezone,current_date from dual;
2.日期到字符操作
c表示字符串,fmt表示一个特殊格式的字符串,函数返回值按照fmt指定的格式显示。nlsparm表示语言,函数将返回c代表的数字。
select trunc(sysdate ,'YEAR') from dual
2、current_date()返回当前会放时区中的当前日期
00
SESSIONTIMEZONE CURRENT_TIMESTAMP
select to_char(trunc(sysdate ,'YYYY'),'YYYY') from dual
LOCALTIMESTAMP
9、next_day()给定一个日期值,返回由第二个参数指出的日子第一次出现在的日期值(应返回相应日子的名称字符串)
00
13-11月-04
--------------- ------------------------------------
时间间隔乘以一个数字
SQL> select months_between(sysdate,date'2001-01-01') from dual;
+08:00 13-11月-03 11.56.28.160000 上午 +08:
11、last_day()
select sysdate,sysdate - interval '7' MINUTE from dual
8、months_between()判断两个日期之间的月份数量
24、to_date([,[,)
--------------- ------------------------------------
4. trunk/ ROUND函数的使用
select trunc(sysdate ) from dual
当前时间减去7小时的时间
12、months_between(,)
nls_numeric_characters ="dg", nls_currency="string"
当前时间减去7天的时间
----------
select sysdate,to_char(sysdate,'yyyy-mm iw-d hh:mi:ss') from dual
l_start number default dbms_utility.get_time;
----------------------------------------
Last day o
1.日期时间间隔操作
SESSIONTIMEZONE CURRENT_DA
select sysdate,to_char(sysdate,'yyyy-ddd hh:mi:ss') from dual
单行转换函数
SQL> select last_day(date'2000-02-01') "Leap Yr?" from dual;
当前时间减去7分钟的时间
SQL> column current_timestamp format a36
下午
LOCALTIMESTAMP CURRENT_TIMESTAMP
函数没有参数,返回当前日期和时间。
2 /
13-3月 -13
-07:00
SQL> column sessiontimezone for a15
SQL> select last_day(sysdate) "Last day of this month" from dual;
This Month
30-11月-03
SQL> alter session set time_zone='-11:00';
x是raw数据类型字符串,函数将raw数据类转换为16进制的数据类型。
SQL> select sessiontimezone,current_timestamp from dual;
-11:00 12-11月-03 04.58.00.243000 下午 -11:
type rc is ref cursor;
begin
3 Years Out
13-11月-03 12.09.15.433000
select to_char(current_timestamp(9),'MI:SSxFF') from dual;
函数返回包含日期d的月份的最后一天
SQL>
下午 00
单行日期函数操作data数据类型,绝大多数都有data数据类型的参数,绝大多数返回的也是data数据类型的值。
select sysdate,to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual
将字符串c中得多字节字符转化成等价的单字节字符。该函数仅当数据库字符集同时包含单字节和多字节字符时才使用。
MONTHS_BETWEEN(SYSDATE,DATE'2001-01-01')
2 /
返回日期d后由dow给出的条件的第一天,dow使用当前会话中给出的语言指定了一周中的某一天,返回的时间分量与d的时间分量相同。
c尾字符串,dset、sset是两个字符集,函数将字符串c由sset字符集转换为dset字符集,sset的缺省设置为数据库的字符集。
函数将rowid数据类型转换为char数据类型。
SQL> select extract(month from sysdate) "This Month" from dual;
SQL> select localtimestamp,to_char(sysdate,'DD-MM-YYYY HH:MI:SS AM') "SYSDATE" from dual;
具体用法和上面的to_char差不多。
--返回当前时间 年月日小时分秒毫秒
当前时间减去7年的时间
389.855143
参考oracle的相关关文档(ORACLE901DOC/SERVER.901/A90125/SQL_ELEMENTS4.HTM#48515)
16、syadate
select sysdate - interval '7' hour from dual
select to_char(current_timestamp(5),'DD-MON-YYYY HH24:MI:SSxFF') from dual;
------
date_value:=extract(date_field from [datetime_value|interval_value])
LOCALTIMESTAMP SYSDATE
----------------------------
select sysdate,sysdate - interval '7' year from dual
select sysdate,sysdate - 8 *interval '2' hour from dual
在oracle中有很多关于日期的函数,如:1、add_months()用于从一个日期值增加或减少一些月份
loop
6、last_day()返回包含了日期参数的月份的最后一天的日期
SQL> select sessiontimezone,current_timestamp from dual;
SQL> select add_months(sysdate,112) "Last Year" from dual;
----------
13、new_time(,,)
SQL>
15、round([,])
会话已更改。
select sysdate,sysdate - interval '7' month from dual
timestamp_value:=localtimestamp
SQL> select localtimestamp from dual;
5、extract()找出日期或间隔值的字段值
SQL> select extract(year from add_months(sysdate,36)) "3 Years Out" from dual;
select sysdate - interval '7' day from dual
14、next_day(,)
for I in 1 .. 1000
返回日期d加上i个月后的结果。i可以使任意整数。如果i是一个小数,那么数据库将隐式的他转换成整数,将会截去小数点后面的部分。
4、dbtimezone()返回时区
相关热词: oracle
本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!
本文地址: https://www.juheyunku.com/sql/oracle/2129.shtml
相关文章
热门TAG
命令 权重 外链 企业网站 白帽 php 织梦教程 dedecms修改内容 javascript 织梦 功能 标签 调用 详解 服务器 网站流量 实例解析 Dedecms 织梦cms HTML tags标签 python jquery教程 jquery windows SEO优化 蜘蛛 搜索引擎 网站收录 JSP最新文章
-
Window下Oracle Database 11g 发行
时间:2020-12-29
-
Oracle如何实现like多个值的
时间:2020-12-29
-
maven添加oracle依赖失败问题
时间:2020-12-29
-
OracleRAC基本概念及入门
时间:2020-12-29
-
Azure File Storage 基本用法
时间:2020-12-26
-
Oracle 权限(grant revoke)
时间:2020-12-26
-
Azure Queue Storage 基本用法
时间:2020-12-26
-
如何对比迁移前后的Orac
时间:2020-12-26
热门文章
-
Azure Queue Storage 基本用法 Azure Storage 之
时间:2020-12-26
-
Oracle存储过程编程详解
时间:2020-12-07
-
win10下oracle 11g安装图文教程
时间:2020-12-25
-
oracle 数据库学习 基本结构介绍
时间:2020-12-13
-
Azure File Storage 基本用法 Azure Storage 之 F
时间:2020-12-26
-
windows使用sqlpus连接oracle 数据库的教程图
时间:2020-12-25
-
Window下Oracle Database 11g 发行版2安装教程
时间:2020-12-29
-
Oracle解锁的方式介绍
时间:2020-12-14
-
linux下oracle设置开机自启动实现方法
时间:2020-12-13
-
Oracle学习记录之使用自定义函数和触发器
时间:2020-12-07
