データベースの日付時刻型をそのまま使用できませんか? – プログラミング – Home

データベースの日付時刻型をそのまま使用...
 
通知
すべてクリア

[解決済] データベースの日付時刻型をそのまま使用できませんか?


KW
 KW
(@KW)
ゲスト
結合: 22年前
投稿: 10
Topic starter  

環境
WinNT
Access2000
ODBC接続
VC++6.0
Win32 Console Applicationから作成

一つのテーブルに4つフィールドがあって、その内の一つに日付時刻型があります。
クラスウィザードを使用して、接続したところ…
m_PICS = _T(");
m_RWEIGHT = 0.0f;
m_RNAME = _T(");
m_TIME = 0;←A
m_nFields = 4;

となっていました。
m_TIMEがAccess上では、yyyy/mm/dd hh:nnで指定しています。

Aの部分が怪しいと思うのですが、それと、表示の部分の「'%s'」も違うと思います。

いろいろ調べていると、「CTIME」、「CString」、「COledatetime」というクラスがそれらし
いのですが、よくわかりませんでしたので、教えを請いに参りました。
御願い致します。


引用未解決
トピックタグ
たいちう
 たいちう
(@たいちう)
ゲスト
結合: 23年前
投稿: 662
 

m_TIME は COleDateTime 型だとすると、
m_TIME = 0L; でどうでしょう。

COleDateTimeのコンストラクタに、int 型を1つだけとるものがないためです。
time_t 型(その実態はlong int)をとるコンストラクタならありますので、
右辺を0(これはint)から0L(long int)にするとうまくいきます。

でもここは、クラスウィザードの吐き出した所なんだよね。
何年か前、苦労しました。
数あるVCのバグの1つだと私は認識しています。


返信引用
KW
 KW
(@KW)
ゲスト
結合: 22年前
投稿: 10
Topic starter  

m_Time=0L;
と変更すると言うことでしょうか?

>m_TIME は COleDateTime 型だとすると、
それは、どちらで宣言すればよろしいのでしょうか?

DoFieldExchange(CFieldExchange* pFX)内では、

RFX_Date(pFX, _T([SYS_TIME]), m_TIME);
となっておりまして、MSDNを見ると
「CTime または TIMESTAMP_STRUCT を使用して時刻と日付のデータを転送します。」
と記述されておりましたので、m_TIMEに入っている意味のわからない数字は時刻を表している
のでしょうか?もし、そうだとすれば、%dのように、'時刻'として取得するにはどのようにす
ればよいのでしょうか?


返信引用
たいちう
 たいちう
(@たいちう)
ゲスト
結合: 23年前
投稿: 662
 

> m_Time=0L;
> と変更すると言うことでしょうか?

ミスタイプだろうからYes。正しくは、m_TIME = 0L;です。

> >m_TIME は COleDateTime 型だとすると、
> それは、どちらで宣言すればよろしいのでしょうか?

すでに宣言されていると思います。ヘッダーファイルを確認してください。

> m_TIMEに入っている意味のわからない数字は時刻を表しているのでしょうか?

この説明では私には判断できません。
正しく設定された時刻を意味の判らない数字といっているのか、
間違った設定で無効な時刻を表しているのか?
どんな数字が入っていました?

> %dのように、'時刻'として取得

時刻を表す文字列が欲しいなら、COleDateTime::Formatを使ってください。
ヘルプはあるよね。


返信引用
KW
 KW
(@KW)
ゲスト
結合: 22年前
投稿: 10
Topic starter  

ヘッダーファイルを確認したところ、宣言が「CTime」となっていました。
意味のわからない数字というのは、グレゴリオ暦+指定日時分の秒数とかだと思います。

ヘッダー部の宣言を「OleDataTime」に変更してやってみます。

後ほど、報告させていただきます。


返信引用
KW
 KW
(@KW)
ゲスト
結合: 22年前
投稿: 10
Topic starter  

//関数開始
COleDateTime date(dbStep1.m_TIME);
//こちらで、オブジェクト作成しています

printf(Time = '%s' ,(LPCTSTR)date.Format(%Y/%m/%d));
//出力です。

出力結果は
1970/01/01でした。
しかし、実際に入っているデータは、2003/09/25です。

デバッグして、実際(dbStep1.m_TIME)に入っているデータを確認してみたところ…
m_dt=37889.500000000
m_status=valid
となっておりましたが、COleDateTimeの使用方法が間違っているんでしょうか?


返信引用
たいちう
 たいちう
(@たいちう)
ゲスト
結合: 23年前
投稿: 662
 

> でもここは、クラスウィザードの吐き出した所なんだよね。
> 何年か前、苦労しました。
> 数あるVCのバグの1つだと私は認識しています。

すみません、勘違いしてました。

私のケースではクラスウィザードのデフォルトがCTime型だったのを
COleDateTime型に変えたため、m_TIME = 0;を直す必要が生じたんでした。
苦労した記憶しか残ってなかったようです。

で、CTime t = 0;はコンパイル通るので、KWさんには全く見当違いの事を
書いてしまったのかもしれません。CTimeにもFormatはありますし。


返信引用
KW
 KW
(@KW)
ゲスト
結合: 22年前
投稿: 10
Topic starter  

そうだったんですか。
でも、折角ですから、COleDateTimeを覚えるために、このままやってみようと思います。

なんとなくですが、現状の日付がおかしいのは、データベースの日付のフォーマットのせいかも
しれません。

データベースでは、yyyy/mm/dd hh:nn となっておりまして、秒単位がないのが原因なのでし
ょうか?


返信引用
たいちう
 たいちう
(@たいちう)
ゲスト
結合: 23年前
投稿: 662
 

> デバッグして、実際(dbStep1.m_TIME)に入っているデータを確認してみたところ…
> m_dt=37889.500000000
> m_status=valid
> となっておりましたが、COleDateTimeの使用方法が間違っているんでしょうか?

COleDateTime date(dbStep1.m_TIME);

の直前と直後のm_TIMEの値が上記の通りであることを確認されているんですよね?
直後のdateの値も。

COleDateTimeの使い方は間違ってないようです。
下記のソースで確認してみてください。

{
COleDateTime m_TIME;
m_TIME.m_dt = 37889.50000;
m_TIME.m_status = COleDateTime::valid;
COleDateTime date(m_TIME);
TRACE(Time = '%s'\n, date.Format(%Y/%m/%d));
}

> データベースでは、yyyy/mm/dd hh:nn となっておりまして、秒単位がないのが原因な
のでし
> ょうか?

アクセスの設定なら表示だけですので、内部的には秒まで(もっと細かく)持ってます。
dateを宣言しているときに、本当にm_dt = 37889.5であることを確認されているなら、
私にはお手上げです。

dbStep1の宣言はどうなっているでしょうか?


返信引用
KW
 KW
(@KW)
ゲスト
結合: 22年前
投稿: 10
Topic starter  

たいちうさんのコードを使用したら、2003/09/25になりました。
元に戻して、値の変化を見ていたのですが、
関数開始
オブジェクト宣言後 25569.375000000(この値が代入されていました)

データベースをオープンすると、
37889.500000000になります。

そして表示が1970/01/01になります。

…。
もしかして、データベースをオープンしたあとに宣言しないといけないのでは?
ちょっとやってみます。


返信引用
KW
 KW
(@KW)
ゲスト
結合: 22年前
投稿: 10
Topic starter  

そのようでした^^
オープンした後に、オブジェクトを宣言することで、値が入るみたいです。
ありがとうございました。


返信引用

返信する

投稿者名

投稿者メールアドレス

タイトル *

プレビュー 0リビジョン 保存しました
共有:
タイトルとURLをコピーしました