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

2007年8月21日

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 阅读(1231) | 评论 (0)编辑 收藏

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 阅读(2454) | 评论 (0)编辑 收藏

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 阅读(2570) | 评论 (1)编辑 收藏

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 阅读(4897) | 评论 (0)编辑 收藏