線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:1938
推到 Plurk!
推到 Facebook!

如何將檔案的更新時間寫到資料庫

尚未結案
astro0803
一般會員


發表:18
回覆:30
積分:9
註冊:2007-05-28

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-11-13 15:15:41 IP:163.18.xxx.xxx 訂閱
因為我的程式是屬於比對檔案,所以我會將一些檔案的內容寫到資料庫裡,以供我判斷是否要比對還是從資料庫裡把資料抓出來即可,但目前我遇到的問題是我如果把檔案的更新時間內容寫到資料庫裡,或著說我該設定此欄位的資料型態為何??
檔案的更新時間格式為:yyyy/mm/dd ampm hh:mm:ss 例如:2007/3/12 上午 10:01:10

如果用@則是剛好相反,為
hh:mm:ss ampm yyyy/mm/dd

如果不能把型態改好,我目前想到的是就把資料切成date和time再抓出值來比對,不過我還是想知道有什麼方法可以解決
Stallion
版主


發表:52
回覆:1600
積分:1995
註冊:2004-09-15

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-11-13 15:27:10 IP:75.18.xxx.xxx 未訂閱
你想太多了!
日期時間就是日期時間!既然將資料庫欄位定義為日期時間後,與檔案本身更新的日期比對,就會以日期時間的方式來比,年月與分秒孰前孰後是日期格式問題!不要把他以字串的格式來想像!
===================引 用 astro0803 文 章===================
因為我的程式是屬於比對檔案,所以我會將一些檔案的內容寫到資料庫裡,以供我判斷是否要比對還是從資料庫裡把資料抓出來即可,但目前我遇到的問題是我如果把檔案的更新時間內容寫到資料庫裡,或著說我該設定此欄位的資料型態為何??
檔案的更新時間格式為:yyyy/mm/dd ampm hh:mm:ss 例如:2007/3/12 上午 10:01:10

如果用@則是剛好相反,為
hh:mm:ss ampm yyyy/mm/dd

如果不能把型態改好,我目前想到的是就把資料切成date和time再抓出值來比對,不過我還是想知道有什麼方法可以解決
astro0803
一般會員


發表:18
回覆:30
積分:9
註冊:2007-05-28

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-11-14 22:43:37 IP:122.123.xxx.xxx 訂閱
我大致上了解s版主的意思了,但我還是有點問題,因資料庫存放時間的欄位型態為timestamp(a),可是存放檔案更新時間的資料型態為TDateTime,這樣我二個一起比較就會出錯,那我到底該怎麼解決呢?

[code cpp]
TDateTime time1;
if(Table1->FieldValues["Update"]==time1) //此時time1變數已存放檔案的更新時間了
{
//符合時去比對
}

[/code]













編輯記錄
astro0803 重新編輯於 2007-11-14 22:47:47, 註解 無‧
astro0803 重新編輯於 2007-11-14 22:49:09, 註解 無‧
astro0803 重新編輯於 2007-11-14 22:50:08, 註解 無‧
astro0803 重新編輯於 2007-11-14 22:51:09, 註解 無‧
astro0803 重新編輯於 2007-11-14 22:53:50, 註解 無‧
astro0803 重新編輯於 2007-11-14 22:56:39, 註解 無‧
astro0803 重新編輯於 2007-11-14 22:57:32, 註解 無‧
astro0803 重新編輯於 2007-11-14 22:58:10, 註解 無‧
bc
一般會員


發表:1
回覆:6
積分:1
註冊:2004-08-18

發送簡訊給我
#4 引用回覆 回覆 發表時間:2007-11-20 17:42:27 IP:203.66.xxx.xxx 未訂閱
你好,小弟認知 一般資料庫以timestamp存取,但每家資料庫所對於timestamp的定義也會有不同,是否可以直接對應TDateTime,要看你所用的資料庫是否可以配合,提供以下網址,他有對timestamp有簡略說明,希望對你有所幫助。

blog.roodo.com/rocksaying/archives/1038137.html

yubad2000
中階會員


發表:0
回覆:44
積分:78
註冊:2007-09-30

發送簡訊給我
#5 引用回覆 回覆 發表時間:2007-12-02 03:01:17 IP:66.171.xxx.xxx 未訂閱
其實時間型態值為Double floating point(實數)
整數位代表日數, 小數位代表時間.
i.e. 時間值1184.25 代表 1970年1月1日 加上1184天, 又 25/100天(六小時)
依據我的經驗, 我想問題是出在時間值得小數位精準度.
i.e. 假設timestamp 取到小數第10位 =>1184.0123456789
假設TDateTime 取到小數第8位 => 1184.01234567
由上可知 兩個值是不相等的.
故建議你先轉換成相同格式的字串再比較
或比較前先round到相同精準度

===================引 用 astro0803 文 章===================
我大致上了解s版主的意思了,但我還是有點問題,因資料庫存放時間的欄位型態為timestamp(a),可是存放檔案更新時間的資料型態為TDateTime,這樣我二個一起比較就會出錯,那我到底該怎麼解決呢?

[code cpp]
TDateTime time1;
if(Table1->FieldValues["Update"]==time1) //此時time1變數已存放檔案的更新時間了
{
//符合時去比對
}

[/code]













------
===波士頓夜未眠===
What a wonderful world!!
Jazz up the world with jazz!!
==================

When I am not programming...
you can find me here:
http://www.holy-war.de/EN/World3/bin/?advertiser=63190
系統時間:2024-04-26 8:05:47
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!