asdtiang的博客 感謝blogjava提供的博客交流平臺

          hsqldb 日期

          Posted on 2010-01-12 17:34 asdtiang 閱讀(3284) 評論(0)  編輯  收藏

          DATE類型用于存儲日期('yyyy-mm-dd'),TIME類型用于存儲時間 ('hh:mm:ss'),DATETIME或TIMESTAMP用于存儲日期和時間。不能用錯了。有些數據庫TIME類型可以存DATE,但是 HSQLDB不行。
          可以給DATATIME類型一個缺省值:
          sql 代碼
          [iocblog.net 來源]

             create cached table directories (   
          dir_id identity NOT NULL,   
          directory varchar(255) NOT NULL,   
          time timestamp default 'now'   
          ); 



          整理一:

          java.sql.Date 只 存儲日期數據不存儲時間數據

          // 會丟失時間數據

          preparedStatement.setDate(1, new java.sql.Date(date.getTime()));

          //可以這樣來處理

          preparedStatement.setTimestamp(1, new Timestamp(new java.util.Date().getTime()));

           

          //想要得到完整的數據,包 括日期和時間,可以這樣

          java.util.Date d = resultSet.getTimestamp(1);

          //這樣處理更合適一些,可 以避免一些潛在Timestamp 問題

          java.util.Date d = new java.util.Date(resultSet.getTimestamp(1).getTime());

             往數據庫存儲的時候可以接收 java.util.Date類型 再用getTime()方法得到代表那個Date對象的long值,再以這個long值構造一個Timestamp對象 存 進數據庫中。

                 從存數據庫里取的時候,可以先得到Timestamp用他的getTime()方法得到long值,再以這個long值構造一個 java.util.Date對象,這樣就可以對這個Date對象操作了。比如說 new SimpleDateFormat("yyyyy-MM-dd HH:mm:ss").format(Date)formatTimestamp)都行~

           

          整理二:

          Timestamp來記錄日期時間還是很方便的,但有時候顯示的時候是不需要小數位后面的 毫秒的,這樣就需要在轉換為String時重新定義格式。

          Timestamp轉化為String:

          SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

          //定義格式,不顯示毫秒

          Timestamp now = new Timestamp(System.currentTimeMillis());

          //獲取系統當前時間

          String str = df.format(now);        

          String轉化為Timestamp:

          SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-ddHH:mm:ss");

          String time = df.format(new Date());

          Timestamp ts = Timestamp.valueOf(time);    

           

          整理三:

          ResultSet中我們經常使用的setDategetDate的數據類型是java.sql.Date,而在平時java程序中我們一般習慣使用 java.util.Date。因此在DAO層我們經常會碰到這倆種數據類型的相互轉換。

          兩者的關系

          java.lang.Object

              |

              +---java.util.Date

                      |

                      +----java.sql.Date

          相互轉換

          1. 使用getTime()函數

          這兩個類都提供了getTime()函數,用于返回對應的毫秒數(long類型)。利用這個函數可以實現轉換:

              java.util.Date utilDate = new java.util.Date(sqlDate.getTime());   // sql -> util

              java.sql.Date sqlDate = new java.sql.Date(utilDate.getTime());   // util -> sql

           

          2. 使用SimpleDateFormat類實現轉換

          SimpleDateFormat 是一個以國別敏感的方式格式化和分析數據的具體類。 它允許格式 化 (date -> text)、語法分析 (text -> date)和標準化。

          SimpleDateFormat dateFormat = new SimpleDateFormate("yyyy-MM-dd HH:mm:ss");

          java.util.Date utilDate = dateFormat.parse(sqlDate.toString());

           

          3. 直接轉換

          由于java.sql.Date是從java.util.Date中繼承過來的,所以可以直接用:

          utilDate = sqlDate;

           

          4. 另類獲得日期的方法:

          SimpleDateFormat sy=new SimpleDateFormat("yyyy");

          SimpleDateFormat sm=new SimpleDateFormat("MM");

          SimpleDateFormat sd=new SimpleDateFormat("dd");

          String syear=sy.format(date);

          String smon=sm.format(date);

          String sday=sd.format(date);

           

          ps:1. java.util.Date類中的getYear()要加上1900才可得到實際值,getMonth()則要加上1。

                  2. 字符串到Date的轉換: Date.valueOf(str),記得引包的時候要引sql的Date包,不是util的Date包

                  3. 字符串到Timestamp 的轉換Timestamp ts = Timestamp.valueOf(time);    



          天蒼蒼,野茫茫,風吹草底見牛羊

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           

          posts - 80, comments - 24, trackbacks - 0, articles - 32

          Copyright © asdtiang

          asdtiang的博客 PaidMailz
          點擊廣告網賺A(每天4個廣告,每個0.0025美元,一個搜索廣告0.03美元)
          主站蜘蛛池模板: 五峰| 商南县| 石台县| 剑河县| 宜春市| 肃宁县| 望城县| 临夏县| 台中市| 舟曲县| 绩溪县| 会宁县| 龙岩市| 泰和县| 外汇| 吴江市| 万源市| 乌恰县| 龙岩市| 岑溪市| 利川市| 罗甸县| 库尔勒市| 同江市| 金坛市| 土默特左旗| 斗六市| 嵊州市| 平遥县| 托克托县| 长岛县| 桦甸市| 吉林市| 永登县| 百色市| 宿松县| 都江堰市| 三门峡市| 淮滨县| 桃园县| 龙海市|