oracle怎么查修改前的fun,oracle 之特殊funxtions应用

第一:时间相加(对于day、hour、minute、second使用的是numtodsinterval函数,方法和numtoyminterval一样。后面可以跟变量)

select numtodsinterval(10, 'day') + numtodsinterval(2, 'hour') +

numtodsinterval(3, 'minute') + numtodsinterval(2.3312, 'second')

from dual

+000000010 02:03:02.331200000

第二:使用dump函数可以查看每一行的内部存数结构。

SQL> select cola,dump(cola) from test_char;

a Typ=96 Len=10: 97,32,32,32,32,32,32,32,32,32

aa Typ=96 Len=10: 97,97,32,32,32,32,32,32,32,32

aaa Typ=96 Len=10: 97,97,97,32,32,32,32,32,32,32

aaaa Typ=96 Len=10: 97,97,97,97,32,32,32,32,32,32

aaaaaaaaaa  Typ=96 Len=10: 97,97,97,97,97,97,97,97,97,97

Typ=96 表示数据类型的ID。Oracle为每一种数据类型都进行了编号。说明char类型的编号是96.

Len =10 表示所在的内部存储的长度(用字节表示)。虽然第一例只存了一个字符’a’,但是它还是占用了10个字节的空间。

97,32,32,32,32,32,32,32,32,32 表示内部存储方式。可见oracle的内部存储是以数据库字符集进行存储的。

97正好是字符a的ASCII码。

可以使用chr函数把ASCII码转成字符。

SQL> select chr(97) from dual;

C

-

a

第三 规则

Numtodsinterval(n, 'second') 获得秒的时间间隔

Numtodsinterval(n, 'minute') 获得分的时间间隔

Numtodsinterval(n, 'month') 获得月的时间间隔

Numtodsinterval(n, 'year') 获得月的时间间隔

增加月份时要非常的小心,应该使用add_months函数。为什么呢?

比如当前日期为2000-2-29日。增加一个月得到的日期就应该是2000-3-31

如果只是简单的加30天或加31天,是无法实现的。所以必须使用add_months函数,它会自动来处理这种月末问题。对年份进行增加也会出现类似的问题

第四:interval的使用

SQL> select sysdate +interval '+3' month from dual;

SYSDATE+INTERV

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

01-12月-11

SQL> select sysdate +interval '+2' month from dual;

SYSDATE+INTERV

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

01-11月-11

SQL>  select to_date('2007-02-28','yyyy-mm-dd')+interval '+3' month from dual;

TO_DATE('2007-

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

28-5月 -07

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值