trunc函数 mysql_TRUNC函数的用法详解

trunc函数 mysql_TRUNC函数的用法详解TRUNC 函数用于对值进行截断 用法有两种 TRUNC NUMBER 表示截断数字 TRUNC date 表示截断日期 1 截断数字 格式 TRUNC n1 n2 n1 表示被截断的数字 n2 表示要截断到那一位 n2 可以是负数 表示截断小数点前 注意 TRUNC 截断不是四舍五入 SQL gt selectTRUNC 15 79 fromdual TRUNC 15 79

TRUNC函数用于对值进行截断。

用法有两种:TRUNC(NUMBER)表示截断数字,TRUNC(date)表示截断日期。

(1)截断数字:

格式:TRUNC(n1,n2),n1表示被截断的数字,n2表示要截断到那一位。n2可以是负数,表示截断小数点前。注意,TRUNC截断不是四舍五入。

SQL> select TRUNC(15.79) from dual;

TRUNC(15.79)

————

15

SQL> select TRUNC(15.79,1) from dual;

TRUNC(15.79,1)

————–

15.7

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

TRUNC(15.79,-1)

—————

10

(2)截断日期:

先执行命令:alter session set nls_date_format=’yyyy-mm-dd hh24:mi:hh’;

截取今天:

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

SYSDATE             TRUNC(SYSDATE,’DD’)

——————- ——————-

2009-03-24 21:31:17 2009-03-24 00:00:00

截取本周第一天:

SQL> select sysdate,trunc(sysdate,’d’) from dual;

SYSDATE             TRUNC(SYSDATE,’D’)

——————- ——————-

2009-03-24 21:29:32 2009-03-22 00:00:00

截取本月第一天:

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

SYSDATE             TRUNC(SYSDATE,’MM’)

——————- ——————-

2009-03-24 21:30:30 2009-03-01 00:00:00

截取本年第一天:

SQL> select sysdate,trunc(sysdate,’y’) from dual;

SYSDATE             TRUNC(SYSDATE,’Y’)

——————- ——————-

2009-03-24 21:31:57 2009-01-01 00:00:00

截取到小时:

SQL> select sysdate,trunc(sysdate,’hh’) from dual;

SYSDATE             TRUNC(SYSDATE,’HH’)

——————- ——————-

2009-03-24 21:32:59 2009-03-24 21:00:00

截取到分钟:

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

SYSDATE             TRUNC(SYSDATE,’MI’)

——————- ——————-

2009-03-24 21:33:32 2009-03-24 21:33:00

获取上月第一天:

SQL> select TRUNC(add_months(SYSDATE,-1),’MM’) from dual

===================================================================

–Oracle trunc()函数的用法

/日期/

1.select trunc(sysdate) from dual  –2011-3-18  今天的日期为2011-3-18

2.select trunc(sysdate, ‘mm’)   from   dual  –2011-3-1    返回当月第一天.

3.select trunc(sysdate,’yy’) from dual  –2011-1-1       返回当年第一天

4.select trunc(sysdate,’dd’) from dual  –2011-3-18    返回当前年月日

5.select trunc(sysdate,’yyyy’) from dual  –2011-1-1   返回当年第一天

6.select trunc(sysdate,’d’) from dual  –2011-3-13 (星期天)返回当前星期的第一天

7.select trunc(sysdate, ‘hh’) from dual   –2011-3-18 14:00:00   当前时间为14:41

8.select trunc(sysdate, ‘mi’) from dual  –2011-3-18 14:41:00   TRUNC()函数没有秒的精确

/*数字/

/*

TRUNC(number,num_digits)

Number 需要截尾取整的数字。

Num_digits 用于指定取整精度的数字。Num_digits 的默认值为 0。

TRUNC()函数截取时不进行四舍五入

*/

9.select trunc(123.458) from dual –123

10.select trunc(123.458,0) from dual –123

11.select trunc(123.458,1) from dual –123.4

12.select trunc(123.458,-1) from dual –120

13.select trunc(123.458,-4) from dual –0

14.select trunc(123.458,4) from dual  –123.458

15.select trunc(123) from dual  –123

16.select trunc(123,1) from dual –123

17.select trunc(123,-1) from dual –120

========================================================================================================

2012-05-17 09:32 466人阅读

select trunc(sysdate ,’dd’) from dual ;   —  2007-9-19

select trunc(sysdate ,’yyyy’) from dual ;   –2007-1-1

select trunc(sysdate ,’mm’) from dual ;   –2007-9-1

begin

dbms_output.put_line( to_char ( (sysdate)    , ‘yyyy-mm-dd hh24:mi:ss’  ) ) ;

dbms_output.put_line( to_char ( (sysdate)+ 1/24/60/10   , ‘yyyy-mm-dd hh24:mi:ss’  ) ) ;

dbms_output.put_line( to_char (  ((sysdate)+ 10 / ( 24*60*60 )   )  , ‘yyyy-mm-dd hh24:mi:ss’  ) ) ;

dbms_output.put_line( to_char (  trunc((sysdate)+ 10 / ( 24*60*60 )   )  , ‘yyyy-mm-dd hh24:mi:ss’  ) ) ;

end ;

/

begin

dbms_output.put_line( ‘当前时间 ‘  ) ;

dbms_output.put_line( to_char ( (sysdate)    , ‘yyyy-mm-dd hh24:mi:ss’  ) ) ;

dbms_output.put_line( ‘当前时间  + 1  s  ‘    ) ;

dbms_output.put_line( to_char ( (sysdate)+ (((1/24)/60)/60   )   , ‘yyyy-mm-dd hh24:mi:ss’  ) ) ;

dbms_output.put_line( ‘当前时间  + 1  s  ‘    ) ;

dbms_output.put_line( to_char ( (sysdate)+ (((5/24)/60)/60   )   , ‘yyyy-mm-dd hh24:mi:ss’  ) ) ;

dbms_output.put_line( ‘当前时间  + 10s  ‘   ) ;

dbms_output.put_line( to_char (  ((sysdate)+  ( 10 / ( 24*60*60 ))    )  , ‘yyyy-mm-dd hh24:mi:ss’  ) ) ;

dbms_output.put_line( ‘当前 日   ‘   ) ;

dbms_output.put_line( to_char (  trunc((sysdate))  , ‘yyyy-mm-dd hh24:mi:ss’  ) ) ;

dbms_output.put_line( ‘当前  第2天 1点  ‘   ) ;

dbms_output.put_line( to_char (  trunc(sysdate)+(  1 +  1/24   ) , ‘yyyy-mm-dd hh24:mi:ss’  ) ) ;

dbms_output.put_line( ‘当前  第2天 9点  ‘   ) ;

dbms_output.put_line( to_char (  trunc(sysdate)+(  1 +  9/24   ) , ‘yyyy-mm-dd hh24:mi:ss’  ) ) ;

end ;

/

写博客是为了记住自己容易忘记的东西,另外也是对自己工作的总结,文章可以转载,无需版权。希望尽自己的努力,做到更好,大家一起努力进步!

如果有什么问题,欢迎大家一起探讨,代码如有问题,欢迎各位大神指正!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/223394.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午2:10
下一篇 2026年3月17日 下午2:11


相关推荐

  • 【智能家居篇】wifi在智能家居中的应用

    【智能家居篇】wifi在智能家居中的应用

    2022年2月4日
    37
  • platform_driver_register调用probe

    platform_driver_register调用probekernel_init中do_basic_setup()->driver_init()->platform_bus_init()->…初始化platformbus(虚拟总线)设备向内核注册的时候platform_device_register()->platform_device_add()->…内核把设备挂在虚拟的platformbus下驱动注册的时候platform_dri

    2022年7月12日
    25
  • 教你读懂蛋白质数据库文件(PDB文件)

    教你读懂蛋白质数据库文件(PDB文件)回答网友提问:什么是HETATM?  并教你读懂蛋白质的PDB文件  作者:小米HETATM非标准基团原子坐标,这个是PDB数据库原子坐标的一种记录格式。如HETATM460PPO4100-2.5027.5874.2251.0024.59PHETATM461O1PO4100-3.3206.5325.0031.00

    2022年6月2日
    42
  • ADB 操作命令详解及用法大全

    ADB 操作命令详解及用法大全ADB操作命令详解及用法大全一、ADB是什么?二、ADB有什么作用?三、ADB命令语法单一设备/模拟器连接多个设备/模拟器连接四、ADB常用命令4.1基本命令4.1.1查看adb的版本信息4.1.2启动adb4.1.3停止adb4.1.4以root权限运行adbd4.1.5指定adbserver的网络端口4.1.5查询已连接的设备/模拟器列表4.2设备连接管理4.2….

    2022年7月27日
    6
  • MINI PCI-E接口_pcie接口原理图

    MINI PCI-E接口_pcie接口原理图1、PCIe3.0X4下图只用了2Lanes,pcie接口分x1、x4、x8、x16接口,向下兼容。含一对差分CLK时钟信号上图:pciex4引脚定义2、minipcie和msata接口一样minipcie和msata接口定义是一样的,可以相互交换使用。都是只有1对Tx和1对Rx,没有差分CLK时钟信号。下图是msata接口,常用于系统盘。上图:msata盘上图:minipcie引脚定义上图:msata引脚定义…

    2025年9月5日
    7
  • basename命令总结

    basename命令总结一 功能说明 basename 命令只要是用于去除路径和文件后缀部分的文件名或者目录名给 basename 指定一个路径 basename 命令会删掉所有的前缀包括最后一个 字符 然后将后缀的字符串显示出来二 语法格式 1 basename 文件 目录 删除路径最后一个 符号 包括 前面的所有内容 2 basename 文件或目录后缀 后缀 可选参数 指定要去除的文件后缀字符串

    2026年3月20日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号