- 浏览: 527602 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (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 2512经常要用数据库,让他自己启动的话,开机太慢,所以用命 ... -
入浅出Oracle--DBA入门、进阶与诊断案例
2011-01-18 10:14 1086数据仓库工具箱:维度建模的完全指南(第二版) Oracle ... -
oracle 树形查找
2010-12-02 10:33 685主题:Oracle树查询及相关函数 http://www.i ... -
create oracle DB auto increment PK trigger
2010-10-11 12:05 1014DROP SEQUENCE seq_chat_group_Id ... -
like %abc%
2010-09-09 00:23 1321关键字: oracle 优化 象 ... -
oracle user manager
2010-09-08 10:05 1014创建与管理用户账户 ... -
Oracle Execute Immediate
2010-06-24 23:10 981EXECUTE IMMEDIATE 在某些情 ... -
oracle 常用的sql
2010-06-20 09:16 1038... -
oracle parallel execution example
2010-06-09 23:07 1283引子:以前一直没太关 ... -
Oracle Parallel Query
2010-06-09 23:06 2105Oracle Parallel Query(OPQ)可 ... -
oracle parallel computing
2010-06-09 23:01 1954用Oracle并行查询发挥多C ... -
Oracle数据库分区表操作方法
2010-06-09 22:46 1229文章转自: http://xu20cn.blog.51cto. ... -
Oracle并行服务器(OPS) Oracle Parallel Server
2010-06-09 22:44 1032文章转载自: http://xu20cn.blog.51c ... -
一个简单的Oracle任务
2010-05-13 08:36 740http://www.cnblogs.com/tohen/ar ... -
ORACLE DATE FUNCTION 大全
2010-05-13 00:47 1150TO_DATE格式 Day: dd number 12 ... -
ORACLE DB 定时任务机制
2010-05-13 00:45 1307简介 本文首先简单介绍了Oracle 8的数据复制的 ... -
ORACLE日期时间函数大全
2010-05-12 08:52 1188ORACLE日期时间函数大全 ... -
paging in oracle
2010-04-10 17:41 683/************************* get ... -
Extract use in oralce
2010-04-09 11:53 936racle中Extract函数的用法 SELEC ... -
about oracle data imp and exp
2010-04-08 20:39 814Oracle数据导入导出 imp/exp就相当于oracle ...
相关推荐
oracle时间函数处理总结大全。个人总结的oracle SQL里常用的时间函数,常用日期型函数 贡献给大家分享。。值得大家作为工具
Oracle数据库处理时间的技巧,。。。。。。。。。。
ORACLE 日期和时间处理汇总,各种日期时间函数,有实例供参考!
Oracle 获取本周、本月、本季、本年的第一天和最后一天
Oracle_Database_11g_SQL日期和时间的存储与处理。
一般数据库中时间的格式为DATE类型,而我们从页面中获取的时间往往为String类型, 这个就需要类型的转换。一般我们会通过调用java.text.SimpleDateFormat JAVA...本文将为大家介绍Oracle时间精确到时、分、秒处理方法。
Oracle中日期格式字段处理[归类].pdf
查看某表的创建时间 SQL>select object_name,created from user_objects where object_name=upper('&table_name'); 查看某表的大小 SQL>select sum(bytes)/(1024*1024) as "size(M)" from user_segments where...
oracle关于日期时间 在oracle中处理日期大全
Oracle数据库处理时间基本准则 81 入侵Oracle数据库常用操作命令 82 Oracle数据库优化及其应用程序研究 83 Instance实例和数据库 85 Oracle数据缓冲区内部机制 85 Oracle 9i数据库密码重用规则分析 87 Oracle数据库...
近段时间很多网友提出监听配置相关问题,客户终端(Client)无法连接服务器端(Server)。本文现对监听配置作一简单介绍,并提出一些客户终端无法连接服务器端的解决思路,愿对广大网友与读者有一些帮助。 一、监听器...
资源主体是自己写的一个Oracle函数,用于处理2020年去除法定节假日之后的任意两个时间点之间所经历的工作日时长(小时)。2020年的法定节假日数据已经整理打包在资源里,开箱即用。可实际应用于生产环境。
ORACLE函数大全 ________________________________________ 作者:[本站编辑] 来源:[CSDN] 浏览:[ ] SQL中的单记录函数 1.ASCII 返回与指定的字符对应的十进制数; SQL> select ascii('A') A,ascii('a') a,...
在Oracle 9i中,按照SQL 99标准,增加了时间间隔型数据INTERVAL YEAR TO MONTH 和 INTERVAL DAY TO SECOND,它们和其他几种数据类型一起使得对时间的处理更加准确。TIMESTAMP、TIMESTAMP WITH TIME ZONE和TIMESTAMP ...
select sysdate from dual 等等一些关于oracle的查询当前时间,日期的一些sql语句的
oralce 时间处理 日期格式 等等
Oracle Applications DBA(Oracle应用程序数据库管理员)比“普通”的Oracle DBA(Oracle数据库管理员)门槛高了很了很多,不仅要有处理数据库问题的能力,还需要了解整个应用程序的构架,从大处着眼,整体考虑问题...
Oracle日期与时间拼接函数以及时间处理函数- -干货 1.时间处理函数 在工作过程中是否有遇到源数据的时间存储为Integer类型的时间格式,如下: 序号 T_TIME_1 1 63272 2 55066 3 55975 4 31394 5 ...
oracle.bat批处理启动命令,不用再服务那里去启动,可以节省很多时间。
//获取时间的年 select to_char(sysdate,'mm') as nowMonth from dual; //获取时间的月 select to_char(sysdate,'dd') as nowDay from dual; //获取时间的日 select to_char(sysdate,'hh24') as nowHour from ...