oracle得到日期


http://www.blogjava.net/gf7/archive/2012/07/01/381933.html

函数trunc是一个Oracle内置的函数,可以对date类型数据进行“度身裁剪”,来适应不同类型的数据需求。

 

在前篇《Oracle日期类型操作几个问题》中,我们已经了解到date类型的基本知识。date类型是一种包括年、月、日、时、分和秒的数据类型,可以表示相对精确的时间信息。内部存储上,date类型是类似于数字类型的,可以通过加减操作实现对日期的推进和后退。

 

但是,日期格式的精确常常给我们带来一些困扰,特别是其中的时分秒信息。很多时候,我们对这部分信息是不需要的。比如指定日期查询、只显示天信息等等。借助To_char虽然可以实现一部分这种需要,但是这样做格式上比较复杂,而且进行了数据类型的转换。是否存在不变化数据类型的方法,对日期型数据进行处理。答案就是trunc函数。

 

trunc(date)

 

截断函数trunc的作用就是将日期类型数据按照指定格式截断,返回一个日期变量数据。例如:

 

SQL> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;

 

TO_CHAR(SYSDATE,'YYYY-MM-DDHH2

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

2010-12-10 20:39:58

 

SQL> select trunc(sysdate) from dual;

 

TRUNC(SYSDATE)

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

2010-12-10

 

SQL> select to_char(trunc(sysdate),'yyyy-mm-dd hh24:mi:ss') from dual;

 

TO_CHAR(TRUNC(SYSDATE),'YYYY-M

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

2010-12-10 00:00:00

 

默认情况下,sysdate函数返回的日期类型数据包括当前的具体时间。通过trunc(date)的处理,直接截取到天信息,返回指定天的零时。

 

trunc函数还支持一个重载参数,格式字符串:trunc(date,format),用于指定截断的位置。如下:

 

//截断到年

SQL> select trunc(sysdate,'yyyy') from dual;

 

TRUNC(SYSDATE,'YYYY')

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

2010-1-1

//截断到月

SQL> select trunc(sysdate,'mm') from dual;

 

TRUNC(SYSDATE,'MM')

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

2010-12-1

//截断到日

SQL> select trunc(sysdate,'dd') from dual;

 

TRUNC(SYSDATE,'DD')

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

2010-12-10

//截断到小时

SQL> select trunc(sysdate,'hh24') from dual;

 

TRUNC(SYSDATE,'HH24')

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

2010-12-10 20:00:00

//截断到分钟

SQL> select trunc(sysdate,'mi') from dual;

 

TRUNC(SYSDATE,'MI')

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

2010-12-10 20:52:00

 

使用不同的格式标志,可以指示不同的截断位置,获取各种零刻时间。

 

 

格式字符串

说明

yyyy或者year

年度第一天(一月一日零时)

mm或者month

月份第一天(一日零时)

dd或者day

日期零时(00:00:00)

小时

hh或者hh24

几时整(XX:00:00)

mi

几分整(XX:XX:00)

 

借助trunc函数和日期类型加减处理,我们可以实现一些特殊日期的设置,实现日期功能,使用在例如Job调度方面。

 

//明天零点

SQL> select to_char(trunc(sysdate)+1,'yyyy-mm-dd hh24:mi:ss') from dual;

 

TO_CHAR(TRUNC(SYSDATE)+1,'YYYY

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

2010-12-11 00:00:00

 

//当天早上十点

SQL> select to_char(trunc(sysdate)+10/24,'yyyy-mm-dd hh24:mi:ss') from dual;

 

TO_CHAR(TRUNC(SYSDATE)+10/24,'

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

2010-12-10 10:00:00

 

//当月三号,上午10点半

SQL> select to_char(trunc(sysdate,'mm')+2+10/24+1/48, 'yyyy-mm-dd hh24:mi:ss') from dual;

注:trunc(sysdate,'mm')将时间取到当前月的1号零时零分零秒,那么加上2就表示当前月的3好零时零分零秒,再加上'10/24'('10/24'本身表示10个小时)就是表示当月3号的十点零分零秒,再加上'1/48'('1/48'本身表示30分钟)就表示当月3号十点三十分零秒

 

TO_CHAR(TRUNC(SYSDATE,'MM')+2+

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

2010-12-03 10:30:00 

 

较复杂的to_char,trunc更加可以发挥日期类型数值本身的特色和优势,无论是代码整洁度还是处理效率都是值得关注的。

 

额外多说一句,trunc本身还具有处理数字截断功能,用于截断指定位数的数字类型。

 

//默认截断到整数,不进行四舍五入;

SQL> select trunc(15.743) from dual;

 

TRUNC(15.743)

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

          15

//截断到小数点后一位;

SQL> select trunc(15.793,1) from dual;

 

TRUNC(15.793,1)

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

          15.7

//截断到小数点前一位;

SQL> select trunc(15.793,-1) from dual;

 

TRUNC(15.793,-1)

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

             10

 

trunc对数字和日期类型处理,也折射出日期类型数据和数字之间的间接关系。

 

原文地址:http://space.itpub.net/17203031/viewspace-681548

 

 trunc不仅可以用来处理日期,还可以用来处理数字

TRUNC(i1,i2)截取i1的i2位而不四舍五入,如果i2是正就截取小数点右边第几位,如果是i2是负就是截取小数点左边第几位。

例如:

 

  
  
  
  
  1. select TRUNC(0.10005767,1) from dual; 
  2.  
  3. TRUNC(0.10005767,1) 1 0.1

而如果trunc函数没有指定参i2,那么其作用为取整,且取整的时候不会四舍五入

例如:

  
  
  
  
  1. select TRUNC(2.60005767) from dual; 
  2.   TRUNC(2.60005767)

round函数和trunc函数的区别:

ROUND(i1,i2)四舍五入,i1四舍五入,如果i2是正保留小数点后i2位。如果是i2是负数,表示保留小数点前面(左边第几位)

TRUNC(i1,i2)截取i1的i2位而不四舍五入,如果i2是正就截取小数点右边第几位,如果是i2是负就是截取小数点左边第几位。





说明二

oracle trunc()函数的用法

oracle 的常用日期格式字符 与trunc函数2009-09-30 17:47

oracle 的常用日期格式字符 与trunc函数

yyyy 年 mm 月 dd 日 hh24 小时 mi 分钟 ss 秒 .sss 毫秒 

w 表示某月的第几周
ww 表示某年的第几周

如果要截取某个时间的某部分时间,可以使用如下函数:
trunc( sysdate,'hh24')    得到按小时取整的时间,该时间的分、秒的值为0。其他的同

例子:统计2008年以来每周执行的语句数。
select count(*) ,to_char(trunc(start_time,'ww'),'yyyy-ww') stat_time from my_log where start_time>=to_date('2008-1','yyyy-mm') group by trunc(start_time,'ww') order by stat_time

oracle trunc()函数的用法!2007-04-30 14:22

------------------rudy

        关于TRUNC函数的format,自己现在有点体会,format为day时,只精确到天,而不管几年几月只要是符合的day就可以了,要想确定一年中的某月的某一天就要用trunc(date,'dd').

通俗的说吧,format为年时,精确到-----年

                             为月时,精确到------年,月(不管哪年,只要是相同的月和哪天)
                              为日时,精确到------年,月,日(不管哪年的哪月,只关心是哪天)   

-----------------郁闷.今天才真正明白了.

1.TRUNC(for dates)
           TRUNC函数为指定元素而截去的日期值。
           其具体的语法格式如下:
           TRUNC(date[,fmt])
           其中:
           date           一个日期值
           fmt                   日期格式,该日期将由指定的元素格式所截去。忽略它则由最近的日期截去
           下面是该函数的使用情况:
           TRUNC(TO_DATE(’24-Nov-1999 08:00 pm’,’dd-mon-yyyy hh:mi am’))
                   =’24-Nov-1999 12:00:00 am’
           TRUNC(TO_DATE(’24-Nov-1999 08:37 pm’,’dd-mon-yyyy hh:mi am’,’hh’))           =’24-Nov-1999 08:00:00 am’

round     (date,'format')未指定format时,如果日期中的时间在中午之前,则将日期中的时间截断为12     A.M.(午夜,一天的开始),否则进到第二天。   

TRUNC(date,'format')未指定format时,将日期截为12     A.M.,不考虑是否在中午之前的条件。

2.TRUNC(for number)
           TRUNC函数返回处理后的数值,其工作机制与ROUND函数极为类似,只是该函数不对指定小数前或后的部分做相应舍入选择处理,而统统截去。
           其具体的语法格式如下
           TRUNC(number[,decimals])
           其中:
           number           待做截取处理的数值
           decimals           指明需保留小数点后面的位数。可选项,忽略它则截去所有的小数部分
           下面是该函数的使用情况:
           TRUNC(89.985,2)=89.98
           TRUNC(89.985)=89
           TRUNC(89.985,-1)=80
           注意:第二个参数可以为负数,表示为小数点左边指定位数后面的部分截去,即均以0记。

(在网上找的关于oracle trunc()函数的用法)

Oracle PL\SQL 操作(三)Oracle函数

1.系统变量函数

(1)SYSDATE

该函数返回当前的日期和时间。返回的是Oracle服务器的当前日期和时间。

select sysdate  from dual;  insert  into purchase  values (‘Small Widget’,’SH’,sysdate, 10);  insert  into purchase  values (‘Meduem Wodget’,’SH’,sysdate-15, 15);

查看最近30天的所有销售记录,使用如下命令:

select *  from purchase  where purchase_date  between (sysdate-30)  and sysdate;

(2)USER

查看用户名。

select  user  from dual;

(3)USERENV

查看用户环境的各种资料。

select userenv(‘TERMINAL’)  FROM dual;

2.数值函数

(1)ROUND 四舍五入函数

ROUND(数值,保留位数)

select round(3.1415,3)  from deul;  select product_name,round(product_price,0) price  from product;

(2)TRUNC 从数中截去小数部分

TRUNC(数值,截断小数点n位后的数)

select trunc(3.145159,3)  from dual;  select trunc(123456.45,-1)  from dual;  select trunc(123456.45)  from dual;  select product_name,trunc(product_price) price  from product;

3.文本函数

(1)UPPER、LOWER和INITCAP

这三个函数更改提供给它们的文体的大小写。

select  upper(product_name)  from product;  select  lower(product_name)  from product;  select initcap(product_name)  from product;

函数INITCAP能够整理杂乱的文本,如下:

select initcap(‘this  TEXT hAd UNpredictABLE  caSE’)  from dual;

(2)LENGTH

求数据库列中的数据所占的长度。

select product_name,length(product_name) name_length  from product  order  by product_name;

(3)SUBSTR

取子串,格式为:

SUBSTR(源字符串,起始位置,子串长度);

create  table item_test(item_id  char(20),item_desc  char(25));  insert  into item_test  values(‘LA-101’,’Can, Small’);  insert  into item_test  values(‘LA-102’,’Bottle, Small’);  insert  into item_test  values(‘LA-103’,’Bottle, Large’);

取编号:

select substr(item_id,4,3) item_num,item_desc  from item_test;

(4)INSTR

确定子串在字符串中的位置,格式如下:

INSTR(源字符串,要查找的字符串,查找起始位置)

select instr(‘this  is line one’,’line’,1)  from dual;

其返回值为子串在源字符串中从起始位置开始第一次出现的位置。上面例子的返回值为9。

select item_desc , instr(item_desc,’,’,1)  from item_test;

(5)LTRIM、RTRIM和TRIM

去除字符串左边的空格、去除字符串右边的空格、去除字符串左右两边的空格。

select ltrim(‘ abc def ‘)  from dual;

4.日期函数

(1)SYSDATE和TRUNC

这两个函数前面已经出现过,即取Oracle服务器系统的日期和截掉小数部分的功能。观察以下操作:

create  table test_date (name  varchar2(20), p_date  date);  insert  into test_date  values(‘name1’,sysdate);  select *  from test_date;  select *  from test_date  where p_date=’25-10月-05‘;  select *  from test_date  where trunc(p_date)= ’25-10月-05‘;

Oracle系统中用SYSDATE取得的不仅包含日期而且还包含的有时间信息,时间信息实际上就是表示儒略日数据中的小数部分。

(2)ADD_MONTHS

该函数返回一个具有与所提供日期相差月份的日期,函数中给出了未来或以前的月份数。语法如下:

ADD_MONTHS(起始日期,增减月数)  select add_months(’26-10月-05‘,2)  from dual;  select add_months(’26-10月-05‘,-2) from dual;

(3)LAST_DAY

返回包含给定日期的那个月的最后一天。语法为:

LAST_DAY(日期)

select last_day(’21-2月-80‘)  from dual;

(4)MONTHS_BETWEEN

返回两个日期间的月份。语法为:

MONTHS_BETWEEN(较晚日期,较早日期)

select months_between(’12-10月-05‘,’12-9月-03‘)  from dual;

5.数据转换函数

(1)TO_CHAR

该函数将日期、时间和数值转换为文本。它的主要价值是提供对日期、时间和数的显示控制;该函数的用法非常灵活,使用较复杂,在此我们仅对经常使用的转换举例说明。

1)格式化日期和时间值

TO_CHAR(日期数据,格式编码)

select to_char(sysdate,’YYYY-MM-DD HH24:MI:SS’)  from dual;  select to_char(sysdate,’HH24:MI:SS’)  from dual;  select to_char(sysdate,‘YYYY’)||‘年’|| to_char(sysdate,'MM')||'月'|| to_char(sysdate,'DD')||'日' 日期  from dual

2)格式化数值

select to_char(5764.12345,'99,999.9999')  from dual;  select to_char(5764.12345,‘09,999.9999') from dual;

(2)TO_DATE

将文本转换为实际的Oracle日期/时间值。格式:

TO_DATE(文本,日期格式)

select to_date(‘2005-10-10 11’,’YYYY-MM-DD HH24’)  from dual;  insert  into item_test  values( ‘name-x’, to_date(‘2005-10-25’,’YYYY-MM-DD’) ) ;

6.其它函数

NVL函数完成一个简单但有用的功能。任何时候给它一个空值,它都返回一个你所选择的值。格式如下:

NAL(输入值,如果输入值为空要返回的值)

select nvl( null,’new_value’)  from dual;  select name,nvl(p_date,sysdate)  from test_date ;

注意:函数中‘输入值’和‘如果输入值为空要返回的值’的类型必须一致。

   /opt/BOCO.DAL/NPM/common/mbin/invoker/GP-NPM_invoker.pl -o "862" -s "2010-01-18 13:00:00" -e "2010-01-18 14:00:00" -task_id "832793" -table_list "tpd_tkgp"


2G:
tpd_msc
tpd_msc_rb
tpd_radio_bts(164数据库)
tpa_radio_sum_t3
tpd_hlr
tpd_hlr_rb
tpd_ggsn
tpd_sgsn
tpd_sgsn_rb
tpd_sdp
tpd_scp
tpd_smp
tpd_smsc_traf
tpd_smsc_rb
tpd_tkgp 

你可能感兴趣的:(oracle得到日期)