熟悉Oracle数据库的人,应该知道:select to_char(sysdate,'yyyy-mm-dd' hh24:mi:ss)from dual将会查询到怎样的结果, 不错,就是类似2012-04-23 20:43:57这样的一个19位的字符串。那么在Java中怎么得到这样一个字符串呢?网上给出了不少类似的例子,但屡试不爽。只好仔细研究Java 的API文档,终于找到了解决办法:

 
    
  1. import java.util.*;  
  2. import java.text.*;  
  3.  
  4.  
  5. public class TestCalendar {  
  6.  
  7.     /**  
  8.      * @param args  
  9.      */  
  10.     public static void main(String[] args) {  
  11.         Calendar cal1 = Calendar.getInstance();  
  12.         TimeZone.setDefault(TimeZone.getTimeZone("GMT+8:00"));       //非常关键的!!! 
  13.         java.text.SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss");  
  14.         System.out.println(sdf.format(cal1.getTime()));  
  15.     }  
  16.  

需要说明的是这样其中TimeZone.setDefault(TimeZone.getTimeZone("GMT+8:00"));  非常关键,没有这句,出来的结果肯定是GMT标准时间,而不是北京时间!

还需要留意,每次都要通过调用Calendar.getInstance()来读取当前时刻的时间,不要被Calendar.getTime()方法所蒙骗:

 

 
    
  1. public class TestCalendar {  
  2.  
  3.     /**  
  4.      * @param args  
  5.      */  
  6.     public static void main(String[] args) {  
  7.         Calendar cal1 = Calendar.getInstance();  
  8.         TimeZone.setDefault(TimeZone.getTimeZone("GMT+8:00"));        
  9.         java.text.SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss SSS");  
  10.         System.out.println(sdf.format(cal1.getTime()));  
  11.         for(int i = 0; i<100; i++){  
  12.             float f = 999999.9f;  
  13.             do {  
  14.                 ff = f - 1.0000001f;  
  15.             } while(f>0.0f);  
  16.         }  
  17. //      cal1 = Calendar.getInstance();  
  18.         System.out.println(sdf.format(cal1.getTime()));  
  19.     }  
  20. }  

会输出两个相同的时间串:

2012-04-23 21:11:56 699
2012-04-23 21:11:56 699

去掉第17行的注释符后,会输出:

2012-04-23 21:13:28 736
2012-04-23 21:13:29 235