- 浏览: 541472 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (339)
- JavaBase (27)
- J2EE (70)
- Database (22)
- Spring (3)
- struts1.x (6)
- struts2.x (16)
- Hibernate (10)
- IBatis (4)
- DWR (1)
- SSH (5)
- Oracle (31)
- HTML (12)
- javascript (11)
- Thinking (3)
- Workflow (5)
- Live (13)
- Linux (23)
- ExtJS (35)
- flex (10)
- php (3)
- Ant (10)
- ps (1)
- work (2)
- Test (1)
- Regular Expressions (2)
- HTTPServer (2)
- 方言 (1)
- 生活 (2)
- Sybase PowerDesigner (0)
最新评论
-
mikey_5:
非常感谢楼主的分享,<parameter propert ...
Check the output parameters (register output parameters failed) IN Ibatis -
影子_890314:
我现在也有这个错误,求解!
Check the output parameters (register output parameters failed) IN Ibatis -
358135071:
学习了,感谢分享!
使用hibernate 代替 mysql 中 limit 進行分頁 -
wjpiao:
你下面的“正确的映射”里面不是还是有number类型吗?
Check the output parameters (register output parameters failed) IN Ibatis -
zh_s_z:
很有用!弄一份吧!
Oracle数据库分区表操作方法
举例说明:
1、日期字符转换函数to_date(),to_char()
SQL:select to_date('20080229132545','yyyy-mm-dd hh24:mi:ss') from dual ;
RESULT:2008-2-29 13:25:45
SQL:select to_char(sysdate,'hh:mi:ss')
TIME from dual; RESULT:10:51:43
2、
SQL:select to_char( to_date(2008,'J'),'Jsp') from dual; RESULT:Two
Thousand Eight
3、查看哪天的年份
SQL:select to_char(to_date('2008-2-29','yyyy-mm-dd'),'year') from
dual; RESULT:two thousand eight
SQL:select
to_char(to_date('2008-2-29','yyyy-mm-dd'),'yyyy') from dual;
RESULT:2008
4、查看哪天的月份
SQL:select
to_char(to_date('2008-2-29','yyyy-mm-dd'),'month') from dual;RESULT:2月
SQL:select to_char(to_date('2008-2-29','yyyy-mm-dd'),'mm') from
dual; RESULT:02
5、查看哪天是星期几
SQL:select to_char(to_date('2008-2-29','yyyy-mm-dd'),'day') from
dual; RESULT:星期五
SQL:select
to_char(to_date('2008-02-29','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE =
American') from dual;
RESULT:friday
SQL:select
to_char(to_date('2008-2-29','yyyy-mm-dd'),'dd') from dual;RESULT:29
6、查看两个日期之间的天数
SQL:select floor(sysdate -
to_date('20080201','yyyymmdd')) from dual; RESULT:28
注:sysdate是2008-02-29
7、取两个日期之间除了周六周日的天数
SQL:
select count(*)
from ( select rownum-1 rnum
from all_objects
where rownum <=
to_date('2008-02-29','yyyy-mm-dd') - to_date('2008-
02-01','yyyy-mm-dd')+1
)
where to_char(
to_date('2008-02-01','yyyy-mm-dd')+rnum-1, 'D' )
not
in (
'6', '7' )
RESULT:
21
8、查看两个日期之间的月
数
SQL:select months_between(to_date('2-29-2008',
'MM-DD-YYYY'),to_date('10-1-2007', 'MM-DD-YYYY')) "MONTHS" FROM DUAL;
RESULT:4.90322580645161
9、next_day函数
next_day(sysdate,6)是从当前开始下一个星期五。后面的数字是从星期日开始算起。
1 2 3 4 5 6 7
日 一 二 三 四 五 六
10、查看小时分秒
select
sysdate ,to_char(sysdate,'hh') from dual;
select sysdate
,to_char(sysdate,'mi') from dual;
select sysdate
,to_char(sysdate,'ss') from dual;
11、取一年的天数(例如
今年2008)
SQL:select add_months(trunc(sysdate,'year'), 12) -
trunc(sysdate,'year') from dual ;RESULT:366
12、
yyyy与rrrr的区别
yyyy 99 0099
rrrr 99 1999
yyyy
01 0001
rrrr 01 2001
13、一年的第几天
SQL:select TO_CHAR(SYSDATE,'DDD'),sysdate from dual ;RESULT:060
注:sysdate是2008-02-29
14、add_months()用于从一个日期值增加或
减少一些月份
SQL:select add_months(sysdate,12) from
dual; RESULT:2009-2-28 11:23:50
15、extract()找出日期或间隔值的字段值
SQL:select
extract(month from sysdate) from dual; RESULT:2
SQL:select
extract(year from add_months(sysdate,36)) from dual; RESULT:2011
16、last_day()返回包含了日期参数的月份的最后一天的日期
SQL:select last_day(sysdate) from
dual; RESULT:2008-2-29
===================================================================================================================
TO_DATE格式
Day:
dd
number 12
dy abbreviated fri
day spelled
out friday
ddspth spelled out, ordinal twelfth
Month:
mm number 03
mon abbreviated mar
month spelled out march
Year:
yy
two digits 98
yyyy four digits 1998
24小时格式下时间范围为:
0:00:00 - 23:59:59....
12小时格式下时间范围为: 1:00:00 - 12:59:59 ....
1.
日期和字符转换函数用法(to_date,to_char)
2.
select to_char(
to_date(222,'J'),'Jsp') from dual
显示Two Hundred Twenty-Two
3.求某天是星期几
select
to_char(to_date('2002-08-26','yyyy-mm-dd'),'day') from dual;
星期一
select
to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE =
American') from dual;
monday
设置日期语言
ALTER SESSION SET
NLS_DATE_LANGUAGE='AMERICAN';
也可以这样
TO_DATE ('2002-08-26',
'YYYY-mm-dd', 'NLS_DATE_LANGUAGE = American')
4.两个日期间的天数
select floor(sysdate -
to_date('20020405','yyyymmdd')) from dual;
5.
时间为null的用法
select id, active_date from table1
UNION
select 1, TO_DATE(null) from dual;
注意要用TO_DATE(null)
6.
a_date between
to_date('20011201','yyyymmdd') and to_date('20011231','yyyymmdd')
那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。
所以,当时间需要精确的时候,觉得to_char还是必要的
7. 日期格式冲突问题
输入的格式要看你安装的ORACLE字符集的类型, 比如: US7ASCII, date格式的类型就是: '01-Jan-01'
alter system set NLS_DATE_LANGUAGE = American
alter session set
NLS_DATE_LANGUAGE = American
或者在to_date中写
select
to_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE =
American') from dual;
注意我这只是举了NLS_DATE_LANGUAGE,当然还有很多,
可查看
select * from nls_session_parameters
select * from
V$NLS_PARAMETERS
日期和字符转换函数用法(to_date,to_char)
We overwrite NLS_DATE_FORMAT
into different formats for the session.
sql> alter session
set nls_date_format = 'DD-MON-RR'; Session altered.
sql> set
pagesize 0
sql> set linesize 130
sql> select * from
nls_session_parameters;
NLS_LANGUAGE AMERICAN
NLS_TERRITORY AMERICA
NLS_CURRENCY $
NLS_ISO_CURRENCY AMERICA
NLS_NUMERIC_CHARACTERS .,
NLS_CALENDAR GREGORIAN
NLS_DATE_FORMAT DD-MON-RR
NLS_DATE_LANGUAGE AMERICAN
NLS_SORT BINARY
NLS_TIME_FORMAT HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT
DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT HH.MI.SSXFF AM
TZH:TZM
NLS_TIMESTAMP_TZ_FORMAT DD-MON-RR HH.MI.SSXFF AM
TZH:TZM
NLS_DUAL_CURRENCY $
NLS_COMP BINARY
15 rows selected.
specify it in sql statement:
sql> select to_date('03-SEP-1999','DD-MON-YYYY') from dual;
03-SEP-99
sql> alter session set nls_date_format =
'MM-DD-YYYY';
Session altered.
sql> select
to_date('03-SEP-99','DD-MON-YY') from dual;
TO_DATE('0
----------
09-03-1999
sql> alter session set
nls_date_format = 'RRRR-MM-DD';
Session altered.
sql> select to_date('03-SEP-1999','DD-MON-YYYY') from dual;
TO_DATE('0
----------
1999-09-03
When we use TO_CHAR function, we get expected results of format
from current sql statement:
sql> alter session set
nls_date_format = 'MM-DD-YY';
Session altered.
sql>
select to_char(sysdate,'dd-mm-yyyy') from dual;
TO_CHAR(SYSDATE,'DD-MM-YYYY')
07-09-1999
sql>
alter session set nls_date_format = 'RR-MON-DD';
Session
altered.
sql> select to_char(sysdate,'dd-mon-yy') from dual;
TO_CHAR(SYSDATE,'DD-MON-YY')
07-sep-99
sql>
select to_char(sysdate,'dd-Mon-yy') from dual;
TO_CHAR(SYSDATE,'DD-MON-YY')
07-Sep-99
8.
select count(*)
from ( select
rownum-1 rnum
from all_objects
where rownum <=
to_date('2002-02-28','yyyy-mm-dd') - to_date('2002-
02-01','yyyy-mm-dd')+1
)
where to_char(
to_date('2002-02-01','yyyy-mm-dd')+rnum-1, 'D' )
not
in (
'1', '7' )
查找2002-02-28至2002-02-01间除星期一和七的天数
在前后分别调用DBMS_UTILITY.GET_TIME, 让后将结果相减(得到的是1/100秒, 而不是毫秒).
9.
select
months_between(to_date('01-31-1999','MM-DD-YYYY'),
to_date('12-31-1998','MM-DD-YYYY')) "MONTHS" FROM DUAL;
1
select months_between(to_date('02-01-1999','MM-DD-YYYY'),
to_date('12-31-1998','MM-DD-YYYY')) "MONTHS" FROM DUAL;
1.03225806451613
10. Next_day的用法
Next_day(date, day)
Monday-Sunday, for format code DAY
Mon-Sun, for format code DY
1-7, for format code D
11
select to_char(sysdate,'hh:mi:ss')
TIME from all_objects
注意:第一条记录的TIME 与最后一行是一样的
可以建立一个函数来处理这个问题
create or replace function sys_date return date is
begin
return sysdate;
end;
select
to_char(sys_date,'hh:mi:ss') from all_objects;
12.
获得小时数
SELECT EXTRACT(HOUR FROM TIMESTAMP
'2001-02-16 2:38:40') from offer
sql> select sysdate
,to_char(sysdate,'hh') from dual;
SYSDATE TO_CHAR(SYSDATE,'HH')
--------------------
---------------------
2003-10-13 19:35:21 07
sql> select sysdate ,to_char(sysdate,'hh24') from dual;
SYSDATE TO_CHAR(SYSDATE,'HH24')
--------------------
-----------------------
2003-10-13 19:35:21 19
获取年月日与此类似
13.
年月日的处理
select
older_date,
newer_date,
years,
months,
abs(
trunc(
newer_date-
add_months( older_date,years*12+months )
)
) days
from ( select
trunc(months_between( newer_date, older_date
)/12) YEARS,
mod(trunc(months_between( newer_date, older_date
)),
12 ) MONTHS,
newer_date,
older_date
from ( select hiredate older_date,
add_months(hiredate,rownum)+rownum newer_date
from emp )
)
14.
处理月份天数不定的办法
select to_char(add_months(last_day(sysdate) +1, -2),
'yyyymmdd'),last_day(sysdate) from dual
16.
找出今年的天数
select add_months(trunc(sysdate,'year'), 12) -
trunc(sysdate,'year') from dual
闰年的处理方法
to_char(
last_day( to_date('02' || :year,'mmyyyy') ), 'dd' )
如果是28就不是闰年
17.
yyyy与rrrr的区别
'YYYY99 TO_C
------- ----
yyyy 99 0099
rrrr 99 1999
yyyy 01 0001
rrrr 01 2001
18.不同时区的处理
select
to_char( NEW_TIME( sysdate, 'GMT','EST'), 'dd/mm/yyyy hh:mi:ss')
,sysdate
from dual;
19.
5秒钟一个间隔
Select TO_DATE(FLOOR(TO_CHAR(sysdate,'SSSSS')/300) * 300,'SSSSS')
,TO_CHAR(sysdate,'SSSSS')
from dual
2002-11-1
9:55:00 35786
SSSSS表示5位秒数
20.
一年的第几天
select TO_CHAR(SYSDATE,'DDD'),sysdate from dual
310 2002-11-6 10:03:51
21.计算小时,分,秒,毫秒
select
Days,
A,
TRUNC(A*24) Hours,
TRUNC(A*24*60 -
60*TRUNC(A*24)) Minutes,
TRUNC(A*24*60*60 -
60*TRUNC(A*24*60)) Seconds,
TRUNC(A*24*60*60*100 -
100*TRUNC(A*24*60*60)) mSeconds
from
(
select
trunc(sysdate) Days,
sysdate - trunc(sysdate) A
from dual
)
9i以上版本
-----------------------------
sql>select to_char(systimestamp,'yyyy-mm-dd hh24:mi:ssxff') time1,
to_char(current_timestamp) time2 from dual;
TIME1
TIME2
-----------------------------
----------------------------------------------------------------
2003-10-24 10:48:45.656000 24-OCT-03 10.48.45.656000 AM +08:00
可以看
到,毫秒在to_char中对应的是FF。
sql> select to_timestamp('2003-10-24
10:48:45.656000','yyyy-mm-dd hh24:mi:ssxff') from dual;
TO_TIMESTAMP('2003-10-2410:48:
-------------------------------------------------
24-10月-03
10.48.45.656000000 上午
22.
floor((date2-date1)
/365) 作为年
floor((date2-date1, 365) /30) 作为月
mod(mod(date2-date1,
365), 30)作为日.
23.next_day函数
next_day(sysdate,6)
是从当前开始下一个星期五。后面的数字是从星期日开始算起。
1 2 3 4 5 6 7
日 一 二 三 四 五 六
24.取出一个时间段中星期日星期六的天数
function weekends(
p_date1 in date, p_date2 in date )
return number
as
l_date1
date default least(p_date1,p_date2);
l_date2 date default
greatest(p_date1,p_date2);
l_days number default
trunc(l_date2-l_date1)+1;
l_cnt number;
begin
select
count(*) into l_cnt
from (select rownum r
from
all_objects where rownum <= l_days)
where
to_char(l_date1+r-1,'dy') in ( 'sat','sun' );
return l_cnt;
end;O
发表评论
-
windows 启动关闭Oracle监听和服务
2012-01-05 10:28 2621经常要用数据库,让他自己启动的话,开机太慢,所以用命 ... -
入浅出Oracle--DBA入门、进阶与诊断案例
2011-01-18 10:14 1127数据仓库工具箱:维度建模的完全指南(第二版) Oracle ... -
oracle 树形查找
2010-12-02 10:33 717主题:Oracle树查询及相关函数 http://www.i ... -
create oracle DB auto increment PK trigger
2010-10-11 12:05 1057DROP SEQUENCE seq_chat_group_Id ... -
like %abc%
2010-09-09 00:23 1368关键字: oracle 优化 象 ... -
oracle user manager
2010-09-08 10:05 1052创建与管理用户账户 ... -
Oracle Execute Immediate
2010-06-24 23:10 1020EXECUTE IMMEDIATE 在某些情 ... -
oracle 常用的sql
2010-06-20 09:16 1083... -
oracle parallel execution example
2010-06-09 23:07 1328引子:以前一直没太关 ... -
Oracle Parallel Query
2010-06-09 23:06 2138Oracle Parallel Query(OPQ)可 ... -
oracle parallel computing
2010-06-09 23:01 1997用Oracle并行查询发挥多C ... -
Oracle数据库分区表操作方法
2010-06-09 22:46 1266文章转自: http://xu20cn.blog.51cto. ... -
Oracle并行服务器(OPS) Oracle Parallel Server
2010-06-09 22:44 1074文章转载自: http://xu20cn.blog.51c ... -
一个简单的Oracle任务
2010-05-13 08:36 776http://www.cnblogs.com/tohen/ar ... -
ORACLE DATE FUNCTION 大全
2010-05-13 00:47 1191TO_DATE格式 Day: dd number 12 ... -
ORACLE DB 定时任务机制
2010-05-13 00:45 1346简介 本文首先简单介绍了Oracle 8的数据复制的 ... -
ORACLE日期时间函数大全
2010-05-12 08:52 1239ORACLE日期时间函数大全 ... -
paging in oracle
2010-04-10 17:41 713/************************* get ... -
Extract use in oralce
2010-04-09 11:53 981racle中Extract函数的用法 SELEC ... -
about oracle data imp and exp
2010-04-08 20:39 862Oracle数据导入导出 imp/exp就相当于oracle ...
相关推荐
Oracle 数据库处理时间的技巧 Oracle 数据库处理时间的技巧是数据库管理员和开发者需要掌握的重要技能。处理时间信息是监控、诊断和处理数据库性能问题的重要依据。但是,Oracle 数据库的时间计量单位是厘秒,可能...
Oracle 中日期处理大全 在 Oracle 中,日期处理是数据库管理系统中一个非常重要的方面。处理日期信息需要精准和细致,否则可能会出现错误的结果。在本节中,我们将详细介绍 Oracle 中日期处理的各种方法和函数。 ...
Oracle数据库在处理日期和时间数据时提供了丰富的函数和操作方式,这些函数可以帮助我们进行日期的转换、计算、格式化以及比较。以下是一些关键的Oracle日期处理函数和SQL语句的详细说明: 1. **TO_DATE函数**:...
在Oracle数据库中,时间区间段的合并是...总结来说,Oracle时间区间段合并的算法利用了窗口函数和分组来识别和合并连续的时间段,能够有效地处理和分析时间序列数据,对于优化数据处理流程和提高查询效率具有重要意义。
Oracle 日期和时间处理汇总 Oracle 日期和时间处理是数据库管理系统中非常重要的一部分,本文汇总了 oracle 中日期和时间处理的各种函数和使用方法,并提供了实例供参考。 一、日期和字符转换函数 Oracle 中...
在"查询oracle时间段操作.txt"文件中,可能包含了具体的SQL查询示例、快照创建步骤和闪回功能的使用指南,以及关于如何有效利用这些工具进行数据恢复和分析的详细说明。阅读这份文件将进一步加深你对Oracle时间段...
Oracle数据库在处理日期时提供了丰富的函数和操作方式,使得日期和时间的管理和计算变得非常灵活。以下是一些关键的知识点: 1. **日期和字符转换**:`to_date` 和 `to_char` 是两个最常用的日期转换函数。`to_date...
总的来说,Oracle的日期时间处理能力强大,提供了多种函数供开发者使用。TO_DATE和TO_TIMESTAMP是其中最常用的,它们允许我们将字符串转换为日期和时间戳类型。通过自定义函数,我们可以扩展这些功能,实现更复杂的...
Oracle 日期和时间的存储与处理 Oracle 日期和时间的存储与处理是 Oracle Database 11g SQL 开发指南中的重要章节。本章节主要介绍了处理并存储一个特定的日期和时间,包括使用 DATE 类型存储日期和时间、使用...
9. **时间性能度量**:在Oracle中,可以使用`DBMS_UTILITY.GET_TIME`来获取系统时间,以衡量SQL语句的执行时间(以1/100秒为单位)。 以上只是Oracle日期处理的一部分,还有许多其他函数和技巧,如`ADD_MONTHS`、`...
在Oracle数据库中,进行时间和秒之间的转换是一种常见的需求,特别是在处理与特定时间点(例如1970-01-01)相关的日期和时间数据时。本文将详细介绍如何在Oracle中实现当前时间与毫秒之间的转换,并提供具体的示例...
标题:Oracle Parallel 并行处理 描述:在Oracle数据库中,通过并行处理技术,一个SQL语句可以被多个线程或进程同时处理,从而显著提升执行效率。 ### Oracle并行处理技术概述 Oracle并行处理是Oracle企业版提供的...
在Oracle数据库中,函数扮演着至关重要的角色,它们允许用户进行复杂的计算、数据处理和信息提取。"Oracle函数大全(CHM格式).rar"这个压缩包显然包含了关于Oracle数据库中各种函数的详细信息,对于学习和查询...
本资料大全将围绕Oracle数据库的核心概念、管理和优化等方面进行深入探讨。 一、Oracle数据库基础 Oracle数据库系统基于SQL标准,采用分布式数据库架构,支持多种数据类型,如数值、字符串、日期、二进制等。其主要...
2. **Oracle函数大全**:Oracle数据库支持大量的内置函数,包括数学函数、字符串函数、日期时间函数、转换函数等,这些函数在编写SQL查询、PL/SQL程序时非常有用。例如,`TO_DATE()`用于将字符串转换为日期,`UPPER...
本资料“Oracle内置函数大全.rar”包含了一份详细的Oracle内置函数讲解,旨在帮助初学者和进阶用户更好地理解和运用这些函数,提升在Oracle数据库操作中的技能。 Oracle内置函数可以分为多种类型,包括算术函数、...
### 使用Oracle计算系统当前时间的毫秒数 在IT领域,特别是数据库管理和应用程序开发中,时间戳是非常重要的数据类型之一。它可以用来记录事件的发生时间、处理时间等关键信息。对于Oracle数据库用户而言,有时需要...
Oracle 日期及时间格式是 Oracle 编程语言中一个重要的组成部分,了解 Oracle 日期及时间格式可以帮助开发者更好地处理日期及时间相关的操作。在 Oracle 中,日期及时间格式可以通过使用 TO_CHAR 函数来实现,该函数...
Oracle数据库在处理时间数据时,通常使用DATE类型来存储日期和时间信息,它可以精确到天。然而,在实际应用中,我们可能需要将时间精确到时、分、秒,这就涉及到数据类型之间的转换,特别是在Java应用程序与Oracle...