Oracle——trunc()函数的使用
trunc是oracle数据库中一种格式化函数。
1.处理日期
1.1.当年第一天:
SELECT TRUNC(SYSDATE,'YYYY') FROM DUAL;
SELECT TRUNC(SYSDATE,'YY') FROM DUAL;
SELECT TRUNC(SYSDATE,'YEAR') FROM DUAL;
--返回结果是2019/1/1
1.2.当月第一天:
SELECT TRUNC(SYSDATE,'MM') FROM DUAL;
SELECT TRUNC(SYSDATE,'MONTH') FROM DUAL;
--返回结果:2019/1/1。很尴尬,我现在是一月份,所以看不出来区别,如果是2月份,应该是2019/2/1
1.3.本周第一天:
SELECT TRUNC(SYSDATE,'D') FROM DUAL;
SELECT TRUNC(SYSDATE,'DAY') FROM DUAL;
--返回结果是:2019/1/27(周日为第一天,当前时间是:2019-1-28,星期二)
1.4.当前小时时间,精确到小时:
SELECT TRUNC(SYSDATE,'HH') FROM DUAL;
SELECT TRUNC(SYSDATE,'HH24') FROM DUAL;
--返回结果是:2019/1/28 16:00:00(当前时间是:2019-01-28 16:50:35)
1.5.当前分钟时间,精确到分钟。(没有精确到秒的用法) :
SELECT TRUNC(SYSDATE,'MI') FROM DUAL;
--返回结果:2019/1/28 16:52:00
1.6.当前季度第一天:
SELECT TRUNC(SYSDATE,'Q') FROM DUAL;
--返回结果:2019/1/1(我当前时间是2019-01-28 16:55:20)
1.7.昨天、明天:
SELECT TRUNC(SYSDATE+1) FROM DUAL;--明天,返回结果:2019/1/29
SELECT TRUNC(SYSDATE-1) FROM DUAL;--昨天,返回结果:2019/1/27
1.8.计算两个时间相差的天数:
SELECT TRUNC(SYSDATE-TO_DATE('2019-2-10 18:00:00','YYYY/MM/DD HH24:MI:SS')) FROM DUAL; --结果:-13
SELECT TRUNC(SYSDATE-TO_DATE('2019-2-10 12:00:00','YYYY/MM/DD HH24:MI:SS')) FROM DUAL; --结果:-12
SELECT TRUNC(SYSDATE-TO_DATE('2019-1-10 12:00:00','YYYY/MM/DD HH24:MI:SS')) FROM DUAL; --结果:18
SELECT TRUNC(SYSDATE-TO_DATE('2019-1-10 18:00:00','YYYY/MM/DD HH24:MI:SS')) FROM DUAL; --结果:17
--注意:我当前时间是2019-01-28 17:02:16。我比较的时间分别是2019-2-10 18:00:00,2019-2-10 12:00:00,2019-1-10 12:00:00,2019-1-10 18:00:00与当前时间比较
1.9.需要注意:
SELECT TO_CHAR(SYSDATE,'YYYY-MM-DD HH24:MI:SS') AS 系统日期,TO_CHAR(TRUNC(SYSDATE),'YYYY-MM-DD HH24:MI:SS') AS trunc日期 FROM DUAL;
--返回结果如下:
系统日期 TRUNC日期
------------------- -------------------
2019-01-28 17:10:19 2019-01-28 00:00:00
--注意这两种查询的区别,
2.处理数字:
用法:TRUNC(NUMBER,length),length表示会保留小数点后面几位数字,如果没有则只保留整数部分,注意:这个不会对数字进行四舍五入
SELECT TRUNC(1234.123456789) FROM DUAL;--
SELECT TRUNC(1234.123456789,0) FROM DUAL;--
SELECT TRUNC(1234.123456789,3) FROM DUAL;1234.123
SELECT TRUNC(1234.123456789,5) FROM DUAL;--1234.12345
Oracle——trunc()函数的使用的更多相关文章
- Oracle trunc()函数的用法
Oracle trunc()函数的用法 /**************日期********************/1.select trunc(sysdate) from dual --2013-0 ...
- Oracle trunc函数
--Oracle trunc()函数的用法/**************日期********************/1.select trunc(sysdate) from dual --2011 ...
- oracle获取本月第一天和最后一天及Oracle trunc()函数的用法
select to_char(trunc(add_months(last_day(sysdate), -1) + 1), 'yyyy-mm-dd') "本月第一天", to_cha ...
- Oracle trunc()函数
Oracle trunc()函数的用法 --Oracle trunc()函数的用法/**************日期********************/1.select trunc(sysd ...
- Oracle trunc()函数的用法--来着心静禅定ing
1.TRUNC(for dates) TRUNC函数为指定元素而截去的日期值. 其具体的语法格式如下: TRUNC(date[,fmt]) 其中: date 一个日期值 fmt 日期格式,该日期将由指 ...
- Oracle trunc() 函数处理数字、日期的整理
--Oracle trunc()函数的用法/**************日期********************/1.select trunc(sysdate) from dual --2013- ...
- Oracle trunc()函数的用法及四舍五入 round函数
--Oracle trunc()函数的用法/**************日期********************/1.select trunc(sysdate) from dual --2011 ...
- [转]Oracle trunc()函数的用法
原文地址:http://www.cnblogs.com/gengaixue/archive/2012/11/21/2781037.html 1.TRUNC(for dates) TRUNC函数为指定元 ...
- Oracle trunc()函数,decode()函数,substr函数,GREATEST函数,java中substring函数的用法
--Oracle trunc()函数的用法/**************日期********************/1.select trunc(sysdate) from dual --2013- ...
- Oracle - Trunc() 函数截取日期&截取数值
Oracle TRUNC函数可以截取数字和日期类型:截取日期:select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual; --显示当前时间 s ...
随机推荐
- vue 的rem 配置和flexible.js的应用
1.环境的配置: C:\Windows\System32\drivers\etc 2.多行注释: 光标放在函数中间,连按两次:“Ctrl+Alt+D”,就会出现以下的内容 3.总结使用过程:vue移动 ...
- Python定期删除文件、整理文件夹
1.根据传入的参数,文件所在目录,匹配文件的正则表达式,过期天数进行删除,这些可写在配置文件del_file.conf. del_file3.py #!/usr/bin/env python # en ...
- 力导向图Demo
<html> <head> <meta charset="utf-8"> <title>力导向图</title> < ...
- HashMap中capacity、loadFactor、threshold、size等概念的解释<转>
最近在看HashMap的源码,有很多概念都很模糊,今天写了一个测试例子,加深对这几个概念的理解,并演示了扩容及树化的过程(见下篇博文:). 注:本文基于JDK 1.8 HashMap的结构 约定 约 ...
- 优化实现Mobile Diffuse动态直接光照shader
项目中美术使用了Unity自带的Mobile/Diffuse这个shader制作了一部分场景素材,这个shader会依赖场景中的动态实时光源,比较耗费. 于是自己手动重写一份,简化shader的消耗, ...
- mpvue 未找到入口 app.json 文件
# 1. 先检查下 Node.js 是否安装成功 $ node -v v8.9.0 $ npm -v 5.6.0 到项目的目录 $ npm install $ npm run dev
- java的ThreadLocal类的使用方法
java的ThreadLocal类的使用方法,ThreadLocal是一个支持泛型的类,用在多线程中用于防止并发冲突问题. 比如以下的一个样例,就是用于线程添加1,可是相互不冲突 package co ...
- IDEA下搭建Shiro-web环境,总是报BasicDataSource,classnotfound;问题解决
进入报错跟踪,查看加载的classloader中没有dbcp相关jar包 猜测结果是,jar没有被加载,但是maven引用没错,而且也能找到对应的class 后来又查看IDEA配置中,相关jar也引入 ...
- 通过User-agent进行SQL注入
声明:本文由Bypass整理并翻译,仅用于安全研究和学习之用. 文章来源:https://hackerone.com/reports/297478 我发现了一个SQL注入漏洞 /dashboard/d ...
- Fiddler 会话过滤功能
我们访问任何网址都会被 Fiddler 捕获,但有时我们只想捕获某个地址,可以使用 Fiddler 的会话过滤,如下我们只过滤出百度的域名 如下,切换到 Filters --- 把 Use Filte ...