Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 1087|回复: 0

oracle trunc()函数的用法

  [复制链接]
  • TA的每日心情
    开心
    2021-12-13 21:45
  • 签到天数: 15 天

    [LV.4]偶尔看看III

    发表于 2011-11-16 10:39:05 | 显示全部楼层 |阅读模式
    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 purchasewhere 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) pricefrom 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) pricefrom 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_lengthfrom productorder 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_descfrom 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
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-22 21:00 , Processed in 0.426193 second(s), 45 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表