随笔 - 14, 文章 - 39, 评论 - 17, 引用 - 0
数据加载中……

2009年3月12日

TortoiseSVN 配合 Beyond Compare 3 或 WinMerge 的设置

日常code工作中,比较麻烦的就是SVN版本冲突时的Merge了,因为TortoiseSVN的比较工具只能比较,不能同时做Merge,
一直以来总是在用WinMerge来扩展TortoiseSVN本身的Differ,虽然方便很多,但是WinMerge和Beyond Compare 3比起来还是不够强大,昨天查看了Beyond Compare 3的帮助文档,试验结果比较理想,可以告别Merge的痛苦了,;-)。
TortoiseSVN的设置如下:
1.选择TortoiseSVN-->Settings
 
2.选择Diff Viewer的设置项,配置扩展比较器的调用命令,WinMerge和Beyond Compare 3的调用字符串如下:
WinMerge:C:\Program Files\WinMerge\WinMergeU.exe -e -x -ub -dl %bname -dr %yname %base %mine
Beyond Compare 3:C:\Program Files\Beyond Compare 3\BComp.exe %mine %base
 

posted @ 2009-03-12 22:08 mlw2000 阅读(1240) | 评论 (0)编辑 收藏

2009年3月7日

GMT和PST--关于时区的知识[转]

GMT和PST--关于时区的知识

1、概念和换算
2、日期中的时区标志
3、在Oracle 9i中正确转换时区
4、redhat9终端方式下更改时区
5、java下的时区......
GMT和PST--关于时区的知识

我们在网上浏览,在虚拟时空漫游世界时,经常会遇到时区的困扰,这篇文章是什么时间发布的?邮件是什么时间发出的?GMT和PST各代表什么意思,如何换算?等等.
我通过互联网搜集了一些小知识,供大家参考。

1、概念和换算
PST - 美国太平洋标准时间
GMT 格林威治标准时间


几个换算公式,因为是24进制,看起来有点怪:
(GMT +8)-16 =PST
PST+7 = GMT
PST+16 = GMT + 8(中国)

我们是东八区,加州是西八区,中间差16个小时。

2、关于日期中的时区标志。

由于都在互联网上,大家在各个时区的事件表示有所不同,因此日期要转换到当前时区的日期和时间,在互联网上,大家一般都用CTS(世界标准时间)有称作GMT(格林尼治时间)。
譬如日期时间为:Sat, 30 Mar 2002 13:27:08 -0800,我们当前所在的时区为正8区(北京时间),则用我们所在时区表示就是 Sat, 30 Mar 2002 29(13+16):27:08 即Sun, 31 Mar 2002 6:27:08 +8000。 ---??
目前存在的时区有:
GMT 格林威治标准时间 GMT
UTC 全球标准时间 GMT
ECT 欧洲中部时间 GMT+1:00
EET 东欧时间 GMT+2:00
ART (阿拉伯)埃及标准时间 GMT+2:00
EAT 东非时间 GMT+3:00
MET 中东时间 GMT+3:30
NET 近东时间 GMT+4:00
PLT 巴基斯坦拉合尔时间 GMT+5:00
IST 印度标准时间 GMT+5:30
BST 孟加拉国标准时间 GMT+6:00
VST 越南标准时间 GMT+7:00
CTT 中国台湾时间 GMT+8:00
JST 日本标准时间 GMT+9:00
ACT 澳大利亚中部时间 GMT+9:30
AET 澳大利亚东部时间 GMT+10:00
SST 所罗门标准时间 GMT+11:00
NST 新西兰标准时间 GMT+12:00
MIT 中途岛时间 GMT-11:00
HST 夏威夷标准时间 GMT-10:00
AST 阿拉斯加标准时间 GMT-9:00
PST 太平洋标准时间 GMT-8:00
PNT 菲尼克斯标准时间 GMT-7:00
MST 西部山脉标准时间 GMT-7:00
CST 中部标准时间 GMT-6:00
EST 东部标准时间 GMT-5:00
IET 印第安那东部标准时间 GMT-5:00
PRT 波多黎各和美属维尔京群岛时间 GMT-4:00
CNT 加拿大纽芬兰时间 GMT-3:30
AGT 阿根廷标准时间 GMT-3:00
BET 巴西东部时间 GMT-3:00
CAT 中非时间 GMT-1:00

3、教你怎样在Oracle 9i中正确转换时区

在Oracle9i之前,虽然有一个NEW_TIME函数可以改变DATE的时间戳部分,但是还没有专门用来存储时区信息的数据类型。在 Oracle9i 中,我们可以使用DBTIMEZONE伪字段查询数据库的时区,使用SESSIONTIMEZONE伪字段查询会话的时区。
但是,对于大多数数据库,这些值都是-07:00之类的偏移值,因此对于NEW_TIME函数是没有用的。Oracle9i有关 NEW_TIME的文档建议使用FROM_TZ来替代,但是这可能会产生误导。FROM_TZ只将一个时区应用到一个时间戳上;它并不能把一个时区转换成 另外一个时区。
其实有一个比较好的方法(从文档中得到这个方法可能有点难)。首先,为了完成这个工作,在正确的时区内需要一个TIMESTAMP WITH ZONE数据类型。然后,如果你将关键字AT TIME ZONE应用到那个值,它就会自动地调整为新的时区和日期。
select (timestamp ';2003-04-06 01:59:59'; at time zone ';PDT';) at time zone ';GMT';   from dual;
06-APR-03 08.59.59.00000000 AM GMT

这个语句将为太平洋白天时间(即其切换到PST之前的时刻)构造一个TIMESTAMP WITH TIME ZONE然后再将其转换到GMT。AT TIME ZONE关键字也接受默认的偏移值语法:
select (timestamp ';2003-04-06 02:00:00'; at time zone ';-07:00';) at time zone   ';00:00'; from dual;
06-APR-03 09.00.00.000000000 AM +00:00
你还可以使用伪字段来自动调整当前会话的时区:
select current_timestamp at time zone dbtimezone from dual;
上面的表达式返回一个当前会话的本地时间(数据类型为时区),重新调整数据库的时区,调整后的时区将与SYSTIMESTAMP的结果相等。有了以上的这些信息,就可以构造一个比较好的NEW_TIME函数:
create or replace function my_new_time (p_dwtz timestamp with time zone,     p_tz varchar2   ) return date is
begin
return cast(p_dwtz at time zone p_tz as date);
end
my_new_time;
/
show errors;
select my_new_time(sysdate,';+08:00';) from dual;
即使第一个参数被标记为一个timestamp with time zone,你依然可以传入一个TIMESTAMP和DATE,这样由于Oracle的自动转型操作,得到的时间将是会话在本地时区的当前时间。这个函数接 受包括偏移值在内的任何可以被TIMESTAMP识别的时区,然后将接受的时区调整为正确的值。

posted @ 2009-03-07 12:32 mlw2000 阅读(2461) | 评论 (0)编辑 收藏

2008年10月26日

HTML Escape Characters: Complete List(html转义字符列表)【转】

     摘要: Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ --><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"&g...  阅读全文

posted @ 2008-10-26 16:43 mlw2000 阅读(2579) | 评论 (1)编辑 收藏

2007年8月21日

javascript日期的常用计算

其中function addDate()是从网上copy来的:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
<SCRIPT LANGUAGE="JavaScript">
<!--

function testAddDate(){
    
var usedate = document.all("doss_card.usedate").value;    
    
var work_year = document.all("doss_card.work_year").value;

    
var tempArry=usedate.split('-');
    
var date=new Date(tempArry[0],tempArry[1]-1);

    
var newdate = addDate(6,work_year,date);
    
var limtyear=newdate.getYear() +'-+ (newdate.getMonth()+1);
    document.all(
"doss_card.limit_month").value = limtyear;
}

function culEndDate(){
    
var inputDate=document.all("rep_month_plan.start_date").value;
    
var datePartArray=inputDate.split('-');
    
//本月开始的第一天
    var curFirstDay=new Date(datePartArray[0],datePartArray[1]-1);
    
//下月开始的第一天
    var nextFirstDay=addDate('5','1',curFirstDay);
    
//下下月开始的第一天
    var nnextFirstDay=addDate('5','2',curFirstDay);
    
//本月最后一天
    var curEndDay= new Date(nextFirstDay.getTime()-1);
    
//下月最后一天
    var nextEndDay= new Date(nnextFirstDay.getTime()-1);
    
    alert(nextEndDay);
    document.all(
"rep_month_plan.curEnddate").value=curEndDay.getYear() +'-+  (curEndDay.getMonth()+1+ '-+curEndDay.getDate();
    document.all(
"rep_month_plan.nextEnddate").value=nextEndDay.getYear() +'-+  (nextEndDay.getMonth()+1+ '-+nextEndDay.getDate();


}


 
function addDate(type,NumDay,vdate){
         
var date=new Date(vdate);
        type 
= parseInt(type) //类型 
         var lIntval = parseInt(NumDay)//间隔
            switch(type){
                 
case 6 ://
                  date.setYear(date.getYear() + lIntval)
                  
break;
                 
case 7 ://季度
                  date.setMonth(date.getMonth() + (lIntval * 3) )
                  
break;
                 
case 5 ://
                  date.setMonth(date.getMonth() + lIntval)
                  
break;
                 
case 4 ://
                  date.setDate(date.getDate() + lIntval)
                  
break
                 
case 3 ://
                  date.setHours(date.getHours() + lIntval)
                  
break
                 
case 2 ://
                  date.setMinutes(date.getMinutes() + lIntval)
                  
break
                 
case 1 ://
                  date.setSeconds(date.getSeconds() + lIntval)
                  
break;
                 
default:
            
          } 
    
return date;
    
//return date.getYear() +'-' +  (date.getMonth()+1) + '-' +date.getDate()+ ' '+ date.getHours()+':'+date.getMinutes()+':'+date.getSeconds()
  } 

//-->

</SCRIPT>
</HEAD>
<FORM METHOD=POST ACTION="">
doss_card.usedate:
<INPUT TYPE="text" NAME="doss_card.usedate" value='2007-06'><BR>
doss_card.work_year:
<INPUT TYPE="text" NAME="doss_card.work_year" value='6'><BR>
doss_card.limit_month:
<INPUT TYPE="text" NAME="doss_card.limit_month"><BR>
<INPUT TYPE="button" value='计算日期相加' onclick='testAddDate()'>
<hr>
当前日期:
<INPUT TYPE="text" NAME="rep_month_plan.start_date" value='2007-06-12'><BR>
当月末日期:
<INPUT TYPE="text" NAME="rep_month_plan.curEnddate"><BR>
下月末日期:
<INPUT TYPE="text" NAME="rep_month_plan.nextEnddate" ><BR>
<INPUT TYPE="button" value='计算月末日期' onclick='culEndDate()'>


</FORM>
<BODY>

</BODY>
</HTML>

posted @ 2007-08-21 00:30 mlw2000 阅读(4902) | 评论 (0)编辑 收藏

2007年6月27日

【转】《紫川》评语

紫川----我最爱的小说!告诉你一个普通少年在爱情与国家兴亡间的感人抉择,一本让你看了一遍感动,看了两遍偶尔心疼,看了三遍非哭不可的小说.这里有世间最真挚的友情,这里有不惜一切的爱情,这里更有超越所有种族的真情,,,有人说紫川是一部史诗,有人说紫川是一部情感的百科全书,还有人说紫川只是流淌在生命中的切许感动..我唯一想说的是:金庸,古龙,老猪

posted @ 2007-06-27 12:46 mlw2000 阅读(297) | 评论 (0)编辑 收藏

2007年3月21日

Java基础问题:汉字问题深入谈[转]

一、主题:关于JAVA的中文问题 
    JAVA的中文问题比较突出,主要表现在控制面板输出,JSP页面输出和数据库访问上。本文尽量避开字体问题,而只谈编码。通过本文,你可以了解JAVA中文问题的由来,问题的解决方法,其中提了一下用JDBC访问数据库的方法。 

二、问题描述: 
1)在中文W2000中文窗口编译和运行,用的是国际版的JDK,连接的是中文W2000下的Cp936编码的SQL SERVER数据库: 

J:exercisedemoencodeHelloWorld>make 
   Created by XCompiler. PhiloSoft All Rights Reserved. 
   Wed May 30 02:54:45 CST 2001 

J:exercisedemoencodeHelloWorld>run 
   Created by XRunner. PhiloSoft All Rights Reserved. 
   Wed May 30 02:51:33 CST 2001 
中文 
[B@7bc8b569 
[B@7b08b569 
[B@7860b569 
中文 
中文 
???? 
中文 
中文 
???? 
?? 
?? 
?? 

2)如果在中文W2000的西文窗口(编码为437)下编译,用JAVA运行则由于无字体而无法正常显示,如果象上面一样在中文W2000的中文窗口运行,输出为: 

J:exercisedemoencodeHelloWorld>run 
   Created by XRunner. PhiloSoft All Rights Reserved. 
   Wed May 30 02:51:33 CST 2001 
???? 
[B@7bc0b66a 
[B@7b04b66a 
[B@7818b66a 
???? 
???? 
???? 
???? 
???? 
???? 
中文 
中文 
???? 

三)分析 

1)出现有乱码(也就是?)。由于只出现?而没出现小方框,说明只是编码有问题,而不是字体问题。 在编码中,如果从一种字符集转换到别一种字符集,比较典型的是从GB2312转换到ISO8859_1(即ASCII),那么很多汉字(半个汉字)是无法映射到西文字符中去的,在这种情形下,系统就把这些字符用?代替。同样,也存在小字符集无法到大字符集的情况,具体原因这里就不详谈了。 

2)出现了中文环境编译,中文环境运行时汉字显示有正确也有不正确的地方,同样,在西文环境下编译,在中文环境下运行时也出现类似情况。这是由于自动(默认)或手工(也就new String(bytes[,encode])和bytes getBytes([encode]))转码的结果。 

2.1)在JAVA源文件-->JAVAC-->Class-->Java-->getBytes()-->new String()-->显示的过程中,每一步都有编码的转换过程,这个过程总是存在的,只是有的时候用默认的参数进行。下面我们一步一步分析为什么出现上面的情形。 

2.2)这里是源代码: 

HelloWorld.java: 
------------------------ 
public class HelloWorld 

    public static void main(String[] argv)
    { 
        try
        { 
            System.out.println("1:"+"中文");
            System.out.println("2:"+"中文".getBytes());
            System.out.println("3:"+"中文".getBytes("GB2312")); 
            System.out.println("4:"+"中文".getBytes("ISO8859_1"));

            System.out.println("5:"+new String("中文".getBytes()));//5 
            System.out.println("6:"+new String("中文".getBytes(),"GB2312")); 
            System.out.println("7:"+new String("中文".getBytes(),"ISO8859_1"));

            System.out.println("8:"+new String("中文".getBytes("GB2312")));//8 
            System.out.println("9:"+new String("中文".getBytes("GB2312"),"GB2312"));
            System.out.println("10:"+new String("中文".getBytes("GB2312"),"ISO8859_1"));

            System.out.println("11:"+new String("中文".getBytes("ISO8859_1")));//11 
            System.out.println("12:"+new String("中文".getBytes("ISO8859_1"),"GB2312"));
            System.out.println("13:"+new String("中文".getBytes("ISO8859_1"),"ISO8859_1"));
        } 
        catch(Exception e)
        { 
            e.printStackTrace(); 
        } 
  } 

为了方便起见,在每个转换的后面加了操作序号,分别为1,2,...,13。 

2.3)需要说明的是,JAVAC是以系统默认编码读入源文件,然后按UNICODE进行编码的。在JAVA运行的时候,JAVA也是采用UNICODE编码的,并且默认输入和输出的都是操作系统的默认编码,也就是说在new String(bytes[,encode])中,系统认为输入的是编码为encode的字节流,换句话说,如果按encode来翻译bytes才能得到正确的结果,这个结果最后要在JAVA中保存,它还是要从这个encode转换成Unicode,也就是说有bytes-->encode字符-->Unicode字符的转换;而在String.getBytes([encode])中,系统要做一个Unicode字符-->encode字符-->bytes的转换。 

在这个例子中,除那个英文窗口编码的时候除外,其实情形下默认编码都是GBK(在本例中,我们暂且把GBK和GB2312等同看待)。 

2.4)由于在未指明在上面的两个用代码实现的转换中,如果未指定encode,系统将采用默认的编码(这里为GBK),我们认为上面的5,6,7和8,9,10是一样的,8和9、11和12也是一样的,所以我们在讨论中将只讨论1,9,10,12,13。其中的2,3,4只是用于测试,不在我们的讨论范围之内。 

2.5)下面我们来跟踪程序中的“中”字的转换历程,我们先说在中文窗口下作的编译和运行过程,注意在下面的字母下标中,我有意识地使用了一些数字,以表示相同,相异还是相关2.5.1)我们先以上面的13个代码段中的的代码9为例: 

步骤 内容 地点 说明 
01: C1 HelloWorld.java C1泛指一个GBK字符 
02: U1 JAVAC读取 U1泛指一个Unicode字符 
03: C1 getBytes()第一步 JAVA先和操作系统交流 
04: B1,B2 getBytes()第二步 然后返回字节数组 
05: C1 new String()第一步 JAVA先和操作系统交流 
06: U1 new String()第二步 然后返回字符 
07: C1 println(String) 能显示“中”字,内容和原来的相同 

2.5.2)然后再以代码段10为例,我们注意到只是: 

步骤 内容 地点 说明 
01: C1 HelloWorld.java C1泛指一个GBK字符 
02: U1 JAVAC读取 U1泛指一个Unicode字符 
03: C1 getBytes()第一步 JAVA先和操作系统交流 
04: B1,B2 getBytes()第二步 然后返回字节数组 
05: C3,C4 new String()第一步 JAVA先和操作系统交流,这时解析错误 
06: U5,U6 new String()第二步 然后返回字符 
07: C3,C4 println(String) 由于中字给分成了两半,在ISO8859_1中刚好也没有字符 

能映射上,所以显示为“??”。在上面的示例中, 
“中文”两个字就显示为“????” 
2.5.3)在完全中文模式下的其它情形类似,我就不多说了 

2.6)我们接着看为什么在西文DOS窗口下编译出来的类在中文窗口下也出现类似情形,特别是为什么居然有的情形下还能正确显示汉字。 

2.6.1)我们还是先以代码段9为例: 

步骤 内容 地点 说明 
01: C1C2 HelloWorld.java C1C2分别泛指一个ISO8859_1字符,“中”字被拆开 
02: U3U4 JAVAC读取 U1U2泛指一个Unicode字符 
03: C5C6 getBytes()第一步 JAVA先和操作系统交流,这时解析错误 
04: B5B6B7B8 getBytes()第二步 然后返回字节数组 
05: C5C6 new String()第一步 JAVA先和操作系统交流 
06: U3U4 new String()第二步 然后返回字符 
07: C5C6 println(String) 虽然同是两个字符,但已不是最初的“两个ISO8859_1字 

符”,而是“两个BGK字符”,“中”显示成了“??” 
而“中文”就显示成了“????” 

2.6.2)下面我们以代码段12为例,因为它能正确显示汉字 

步骤 内容 地点 说明 

01: C1C2 HelloWorld.java C1C2分别泛指一个ISO8859_1字符,“中”字被拆开 
02: U3U4 JAVAC读取 U1U2泛指一个Unicode字符
03: C1C2 getBytes()第一步 JAVA先和操作系统交流(注意还是正确的哦!) 
04: B5B6 getBytes()第二步 然后返回字节数组(这是很关键的一步!) 
05: C12 new String()第一步 JAVA先和操作系统交流(这是更关键的一步,JAVA已经知道B5B6要解析成一个汉字!) 
06: U7 new String()第二步 然后返回字符(真是一个项两!U7包含了U3U4的信息) 
07: C12 println(String) 这就原来的“中”字,很委屈被JAVAC冤枉了一回,不过被程序员拨乱反正了一下!当然,“中文”两个字都能正确显示了! 

3)那为什么有的时候用JDBC的 
new String(Recordset.getBytes(int)[,encode]) 
Recordset.getSting(int) 
Recordset.setBytes(String.getBytes([encode])) 
和 
Recordset.setString(String) 
的时候会出现乱码了呢? 

其实问题就出现在编写JDBC的的也考虑了编码问题,它从数据库读取数据后,可能自作主张做了一个从GB2312(默认编码)到Unicode的转换,我的这个WebLogic For SQL Server的JDBC Driver就是这样的,当我读字串的时候,发出读到的不是正确的汉字,可恨的是我却可以直接写汉字字串,这让人多少有点难以接受! 
也就是说,我们不得不在读或写的时候进行转码,尽管这个转码有的时候不是那么明显,这是因为我们使用了默认的编码进行转码。JDBC Driver所做的操作,我们只有进入到源代码内部才能清楚,大家认为呢?

posted @ 2007-03-21 09:18 mlw2000 阅读(395) | 评论 (0)编辑 收藏

2007年3月17日

如何修改eclipse中的"Mark occurence highlight colour"(即“标记当前高亮”的颜色)[转]

搜了半天终于找到了:
Hi

The 'mark occurences' feature is really useful, unfortunately it is a light shade of yellow and the window colour is a light beige, therefore it doesn't show up. The only way I can find the occurences is to move my mouse cursor up and down the margin until it becomes a hand.

I have looked all through all the preferences and I can't see how to change that colour. Is it a system colour, or FDT, and is it actually possible to change?

Any help gratefully appreciated.
Jake


============================================================
Here is the way you can change the color:

1. Select the Menu Window->Preferences
2. Select in the tree General->Editors->Text Editors->Annotations
3. Select AS Occurence
4. At the right there is a small Button Color, klick it and select a new color.


刚刚试过,eclipse 3.20能用此方法修改

posted @ 2007-03-17 00:31 mlw2000 阅读(2412) | 评论 (6)编辑 收藏

2007年3月1日

关于读取文件内容时报sun.io.MalformedInputException的问题 [转]

在网上找到的原因是这样的:
这个问题产生的原因是IBM在JDK 1.4版本中为了追求对io通道的高效率改变了JDK 1.3中对io通道中异常处理的策略。IBM JDK 1.4中对于io通道的异常处理更加严格,因此系统中会报上面的错误。
解决这一问题的办法是不使用IBM JDK 1.4中默认的io通道,而使用nio通道。具体的做法如下:
1.打开管理控制台,找到并选择运行这个JSP的应用服务器
2.依次选择进程定义,java虚拟机,一般JVM自变量
3.添加-Dibm.stream.nio=true
4.确定,保存
5.重新启动该服务器

本来我就怀疑又是IBM JDK的问题,果然被我不幸言中了,再次表示一下郁闷!

我发现在我需要读取的文件当中存在这样的一些乱码字符

我原来是用下面这段程序读取这个文件的内容并打印的:
FileReader fr = new FileReader(file);
BufferedReader br = new BufferedReader(fr);
String str="";
String result = "";
while((str=br.readLine())!=null){
    result += str + "\n";
}
即逐行读取的方法,我想也是一般的方法,但是就是这个readline方法导致了IBM JDK 1.4.2 报了这个sun.io.MalformedInputException的问题.

我现在使用的解决方法如下:
String result = "";
StringBuffer sBuffer=new StringBuffer();
FileInputStream fis=new FileInputStream(file);
BufferedInputStream bis=new BufferedInputStream(fis);
String tempStr;
byte[] b = new byte[1024];
int i = 0;
while ((i = bis.read(b)) > 0) {
    tempStr=new String(b,0,i);
    sBuffer.append(tempStr);
}
result = sBuffer.toString();

即逐字节读取的方法.这样处理就可以正常读取了!

具体到底为什么会出现这种问题现在还没弄明白,估计也弄不明白了!

posted @ 2007-03-01 10:08 mlw2000 阅读(3752) | 评论 (4)编辑 收藏

2007年2月15日

Oracle关于时间/日期的操作 (转)

Oracle关于时间/日期的操作

1.日期时间间隔操作

当前时间减去7分钟的时间
select  sysdate,sysdate - interval '7' MINUTE  from dual
当前时间减去7小时的时间
select  sysdate - interval '7' hour  from dual
当前时间减去7天的时间
select  sysdate - interval '7' day  from dual
当前时间减去7月的时间
select  sysdate,sysdate - interval '7' month from dual
当前时间减去7年的时间
select  sysdate,sysdate - interval '7' year   from dual
时间间隔乘以一个数字
select  sysdate,sysdate - 8 *interval '2' hour   from dual

2.日期到字符操作
select  sysdate,to_char(sysdate,'yyyy-mm-dd hh24:mi:ss')  from dual
select  sysdate,to_char(sysdate,'yyyy-mm-dd hh:mi:ss')  from dual
select  sysdate,to_char(sysdate,'yyyy-ddd hh:mi:ss')  from dual
select  sysdate,to_char(sysdate,'yyyy-mm iw-d hh:mi:ss')  from dual
   参考oracle的相关关文档(ORACLE901DOC/SERVER.901/A90125/SQL_ELEMENTS4.HTM#48515)

3. 字符到日期操作
select  to_date('2003-10-17 21:15:37','yyyy-mm-dd hh24:mi:ss') from dual
具体用法和上面的to_char差不多。

4. trunk/ ROUND函数的使用
select  trunc(sysdate ,'YEAR')  from dual
select  trunc(sysdate )  from dual
select  to_char(trunc(sysdate ,'YYYY'),'YYYY')  from  dual

5.oracle有毫秒级的数据类型
--返回当前时间 年月日小时分秒毫秒
select to_char(current_timestamp(5),'DD-MON-YYYY HH24:MI:SSxFF') from dual;
--返回当前 时间的秒毫秒,可以指定秒后面的精度(最大=9)
select to_char(current_timestamp(9),'MI:SSxFF') from dual;

6.计算程序运行的时间(ms)
declare
    type rc is ref cursor;
    l_rc rc;
    l_dummy all_objects.object_name%type;
    l_start number default dbms_utility.get_time;
begin
    for  I  in 1 .. 1000
    loop
        open l_rc for
          'select object_name  from all_objects '||

'where object_id = ' || i;
        fetch l_rc into l_dummy;
        close l_rc;
    end loop;
    dbms_output.put_line
    ( round( (dbms_utility.get_time-l_start)/100, 2 ) ||
      ' seconds...' );
end;

posted @ 2007-02-15 16:04 mlw2000 阅读(227) | 评论 (0)编辑 收藏

DB2中有关日期和时间的函数,及应用(转)

DAYNAME         返回一个大小写混合的字符串,对于参数的日部分,用星期表示这一天的名称(例如,Friday)。  
DAYOFWEEK    返回参数中的星期几,用范围在 1-7 的整数值表示,其中 1 代表星期日。  
DAYOFWEEK_ISO 返回参数中的星期几,用范围在 1-7 的整数值表示,其中 1 代表星期一。  
DAYOFYEAR          返回参数中一年中的第几天,用范围在 1-366 的整数值表示。  
DAYS                     返回日期的整数表示。  
JULIAN_DAY         返回从公元前 4712 年 1 月 1 日(儒略日历的开始日期)到参数中指定日期值之间的天数,用整数值表示。  
MIDNIGHT_SECONDS  返回午夜和参数中指定的时间值之间的秒数,用范围在 0 到 86400 之间的整数值表示。  
MONTHNAME               对于参数的月部分的月份,返回一个大小写混合的字符串(例如,January)。  
TIMESTAMP_ISO         根据日期、时间或时间戳记参数而返回一个时间戳记值。  
TIMESTAMP_FORMAT 从已使用字符模板解释的字符串返回时间戳记。  
TIMESTAMPDIFF        根据两个时间戳记之间的时差,返回由第一个参数定义的类型表示的估计时差。  
TO_CHAR                   返回已用字符模板进行格式化的时间戳记的字符表示。TO_CHAR 是 VARCHAR_FORMAT 的同义词。  
TO_DATE                  从已使用字符模板解释过的字符串返回时间戳记。TO_DATE 是 TIMESTAMP_FORMAT 的同义词。  
WEEK                     返回参数中一年的第几周,用范围在 1-54 的整数值表示。以星期日作为一周的开始。  
WEEK_ISO            返回参数中一年的第几周,用范围在 1-53 的整数值表示。

要使当前时间或当前时间戳记调整到 GMT/CUT,则把当前的时间或时间戳记减去当前时区寄存器: 
current time - current timezone 
current timestamp - current timezone 

给定了日期、时间或时间戳记,则使用适当的函数可以单独抽取出(如果适用的话)年、月、日、时、分、秒及微秒各部分: 
YEAR (current timestamp) 
MONTH (current timestamp) 
DAY (current timestamp) 
HOUR (current timestamp) 
MINUTE (current timestamp) 
SECOND (current timestamp) 
MICROSECOND (current timestamp) 

因为没有更好的术语,所以您还可以使用英语来执行日期和时间计算: 
current date + 1 YEAR 
current date + 3 YEARS + 2 MONTHS + 15 DAYS 
current time + 5 HOURS - 3 MINUTES + 10 SECONDS 

从时间戳记单独抽取出日期和时间也非常简单: 
DATE (current timestamp) 
TIME (current timestamp)

而以下示例描述了如何获得微秒部分归零的当前时间戳记: 

CURRENT TIMESTAMP - MICROSECOND (current timestamp) MICROSECONDS 

如果想将日期或时间值与其它文本相衔接,那么需要先将该值转换成字符串。为此,只要使用 CHAR() 函数: 

char(current date) 
char(current time) 
char(current date + 12 hours) 

要将字符串转换成日期或时间值,可以使用: 

TIMESTAMP ('2002-10-20-12.00.00.000000') 
TIMESTAMP ('2002-10-20 12:00:00') 
DATE ('2002-10-20') 
DATE ('10/20/2002') 
TIME ('12:00:00') 
TIME ('12.00.00') 

TIMESTAMP()、DATE() 和 TIME() 函数接受更多种格式。上面几种格式只是示例,我将把它作为一个练习,让读者自己去发现其它格式。 

有时,您需要知道两个时间戳记之间的时差。为此,DB2 提供了一个名为 TIMESTAMPDIFF() 的内置函数。但该函数返回的是近似值,因为它不考虑闰年,而且假设每个月只有 30 天。以下示例描述了如何得到两个日期的近似时差: 

timestampdiff (<n>, char( 
timestamp('2002-11-30-00.00.00')- 
timestamp('2002-11-08-00.00.00'))) 

对于 <n>,可以使用以下各值来替代,以指出结果的时间单位: 

1 = 秒的小数部分  
2 = 秒  
4 = 分  
8 = 时  
16 = 天  
32 = 周  
64 = 月  
128 = 季度  
256 = 年  
当日期很接近时使用 timestampdiff() 比日期相差很大时精确。如果需要进行更精确的计算,可以使用以下方法来确定时差(按秒计): 

(DAYS(t1) - DAYS(t2)) * 86400 +   
(MIDNIGHT_SECONDS(t1) - MIDNIGHT_SECONDS(t2)) 

为方便起见,还可以对上面的方法创建 SQL 用户定义的函数: 

CREATE FUNCTION secondsdiff(t1 TIMESTAMP, t2 TIMESTAMP) 
RETURNS INT 
RETURN ( 
(DAYS(t1) - DAYS(t2)) * 86400 +   
(MIDNIGHT_SECONDS(t1) - MIDNIGHT_SECONDS(t2)) 



如果需要确定给定年份是否是闰年,以下是一个很有用的 SQL 函数,您可以创建它来确定给定年份的天数: 

CREATE FUNCTION daysinyear(yr INT) 
RETURNS INT 
RETURN (CASE (mod(yr, 400)) WHEN 0 THEN 366 ELSE  
        CASE (mod(yr, 4))   WHEN 0 THEN  
        CASE (mod(yr, 100)) WHEN 0 THEN 365 ELSE 366 END  
        ELSE 365 END 
END)@ 

最后,以下是一张用于日期操作的内置函数表。它旨在帮助您快速确定可能满足您要求的函数,但未提供完整的参考。有关这些函数的更多信息,请参考 SQL 参考大全。 

SQL 日期和时间函数  
DAYNAME 返回一个大小写混合的字符串,对于参数的日部分,用星期表示这一天的名称(例如,Friday)。  
DAYOFWEEK 返回参数中的星期几,用范围在 1-7 的整数值表示,其中 1 代表星期日。  
DAYOFWEEK_ISO 返回参数中的星期几,用范围在 1-7 的整数值表示,其中 1 代表星期一。  
DAYOFYEAR 返回参数中一年中的第几天,用范围在 1-366 的整数值表示。  
DAYS 返回日期的整数表示。  
JULIAN_DAY 返回从公元前 4712 年 1 月 1 日(儒略日历的开始日期)到参数中指定日期值之间的天数,用整数值表示。  
MIDNIGHT_SECONDS 返回午夜和参数中指定的时间值之间的秒数,用范围在 0 到 86400 之间的整数值表示。  
MONTHNAME 对于参数的月部分的月份,返回一个大小写混合的字符串(例如,January)。  
TIMESTAMP_ISO 根据日期、时间或时间戳记参数而返回一个时间戳记值。  
TIMESTAMP_FORMAT 从已使用字符模板解释的字符串返回时间戳记。  
TIMESTAMPDIFF 根据两个时间戳记之间的时差,返回由第一个参数定义的类型表示的估计时差。  
TO_CHAR 返回已用字符模板进行格式化的时间戳记的字符表示。TO_CHAR 是 VARCHAR_FORMAT 的同义词。  
TO_DATE 从已使用字符模板解释过的字符串返回时间戳记。TO_DATE 是 TIMESTAMP_FORMAT 的同义词。  
WEEK 返回参数中一年的第几周,用范围在 1-54 的整数值表示。以星期日作为一周的开始。  
WEEK_ISO 返回参数中一年的第几周,用范围在 1-53 的整数值表示。

posted @ 2007-02-15 15:25 mlw2000 阅读(1696) | 评论 (1)编辑 收藏