Oracle中的时间字段的处理方式
来源:互联网 发布:乡村旅游源码下载 编辑:程序博客网 时间:2024/05/17 05:52
首先明确一点oracle中的时间字段类型用(timestamp),而Oracle中的默认存储方式是“23-8月-2013”这样类似的方式存储的
当在进行insert的时候 通常要根据自己的喜好,比方说按照年月日这样的顺序进行输入,或者日月年这样的方式输入。例子:
insert into cwh_warningtrick (id,wtk_warningtime) values(seq_cwh_warningtrick.nextval,to_date('2003-08-21','YYYY-MM-DD'));
而在取数据的时候 也可以以不同的顺序取出来,简单来个例子:
select (to_char(字段名,'YYYY-MM-DD'))字段名 from 表名;
或者select (to_char(字段名,'MM-DD-YYYY'))字段名 from 表名;
都是根据自己的喜好
一下部分为转载:
函数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;
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对数字和日期类型处理,也折射出日期类型数据和数字之间的间接关系。
- Oracle中的时间字段的处理方式
- oracle中的date类型字段的处理
- Oracle数据库中对时间字段的处理方法
- ojdbc操作oracle时间类型字段的处理
- Oracle中的日期字段处理
- oracle中的clob字段的回车换行的处理
- python 处理dataframe中的时间字段
- 时间的处理方式
- ORacle截取时间字段中的时、分
- Oracle中的一些时间处理
- oracle的时间处理
- oracle 的时间处理
- oracle的时间处理
- 使用Hibernate处理Oracle中的Blob字段
- MySql中时间字段的处理
- 今天学到的,字段截取时间,字段连接方式
- Lucene 对字段的处理方式
- Oracle分区字段的修改方式
- 博主前来报道
- my js library
- 为不同种类的文档建立文档模板
- IOS应用如何配置iTunes文件共享
- Struts2 基础
- Oracle中的时间字段的处理方式
- linux并口驱动概述
- 使用ASP.NET上传图片汇总2
- 使用ollyodb破解AspriseOCR.dll
- encodeURI 2次
- 限制文本框只能输入数字和小数点
- Struts2和MVC
- JQuery文本改变触发事件
- dfasdfad