お世話になります。
PL/SQLでDATE型のデータの日時を取得する方法を教えてください。
PL/SQLでDBの値を、TO_CHARで取ってきて、その値をTO_DATEすると、時刻が落ちてしまいます。
charWorkEndDate VARCHAR2(20);
dtWorkEndDate DATE;
charWorkEndDate:= to_char(V00061_Rec.S_DATE5, 'YYYY/MM/DD HH24:MI:SS');
dtWorkEndDate := to_date(charWorkEndDate, 'YYYY/MM/DD HH24:MI:SS');
出力結果
--charWorkEndDate- [2005/12/25 06:00:19]
--dtWorkEndDate- [05-12-25]
to_dateの1つ目の引数にシングルクォーテーションが必要かと思い、
dtWorkEndDate := to_date('''||charWorkEndDate||''', 'YYYY/MM/DD HH24:MI:SS');
としてみたのですが、その場合、「ORA-01841: (周)年は-4713と+9999の間の0以外の数を指定する必要があります」とのエラーが出てしまいます。
どなたかDATE型のデータの時刻を取る方法をご存知でしたら、教えていただけますでしょうか。
よろしくお願いします。
No.2
- 回答日時:
実際にDate型に[05-12-25]の値が入っているわけではなく、単に表示する時に時刻を削って表示しているだけだと思われます。
そのままdtWorkEndDateをINSERTして、
SELECT
TO_CHAR([dtWorkEndDateを入れたテーブル列名,'YYYY/MM/DD HH24:MI:SS')
FROM
[dtWorkEndDateを入れたテーブル行名]
;
としてみてください。
DBに値がちゃんと入っているのが確認できると思われます。
回答ありがとうございます。
そのままdtWorkEndDateをINSERTしたのですが、
DBには日付しか入りませんでした。
>単に表示する時に時刻を削って表示しているだけだと思われます。
INSERTの前の時点では、
TO_CHAR(dtWorkEndDate, 'YYYY/MM/DD HH24:MI:SS')
で表示させたところ、時間が入っていました。
INSERT文は
execute immediate
'INSERT INTO テーブル名 VALUES(''' ||
dtWorkEndDate || ''')';
となっています。
INSERT文のログは、VALUES('05-01-04')となっていました。
もし何かお気づきの点がありましたらご教授下さい。
よろしくお願いします。
No.1ベストアンサー
- 回答日時:
試してないので憶測ですが、
おそらくdtWorkEndDate は時間ももってます。
日付のデフォルト出力フォーマットが[yy-mm-dd]になってるので、時間が表示されないだけです。
to_char(to_date(charWorkEndDate, 'YYYY/MM/DD HH24:MI:SS'), 'YYYY/MM/DD HH24:MI:SS');
とすれば、時間も表示されませんか?
返信ありがとうございます。
>to_char(to_date(charWorkEndDate, 'YYYY/MM/DD HH24:MI:SS'), 'YYYY/MM/DD HH24:MI:SS');
で時間も取得できました。
重ねてもしご存知でしたら教えていただきたいのですが、
この取得した日時をDATE型でINSERTしたい場合は、
どのような記述が適切なのでしょうか。
TO_DATEでは日時が落ちてしまい、
'to_char(to_date(charWorkEndDate, 'YYYY/MM/DD HH24:MI:SS'), 'YYYY/MM/DD HH24:MI:SS')'
ではリテラルと書式が一致しないとエラーになってしまいます。
初期化パラメータNLS_DATE_FORMATを変更するしかないのでしょうか。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) データベースから絞り込んでデータを読み込み 1 2023/02/21 19:51
- JavaScript gasについて 1 2022/05/31 21:51
- 英語 to date 2 2023/05/23 23:22
- Visual Basic(VBA) ①ExcelVBAでカレンダーを作り、別のユザーフォームで日付を入力したいのですがエラーになります。 1 2023/02/17 18:39
- その他(プログラミング・Web制作) python 気象データの取得 2 2023/06/20 23:54
- Visual Basic(VBA) VBAで時間(00:00形式)を積算(足し算)したい 1 2022/11/15 17:04
- Visual Basic(VBA) VBAで日付入力しているのですが 4 2023/03/02 11:25
- Excel(エクセル) エクセルの数式で教えてください。 2 2022/12/23 14:57
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- Excel(エクセル) Excel 数行を1組とする300組ほどあるデータの項目を揃えたいです。 3 2023/01/26 19:38
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
SQLで特定の項目の重複のみを排除した全項目を取得する方法
その他(プログラミング・Web制作)
-
PL/SQL PLS-00103エラーについて
Oracle
-
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
-
4
GROUP BYを行った後に結合したい。
Oracle
-
5
select句副問い合わせ 値の個数が多すぎます
Oracle
-
6
SQLローダーCSV取込で、囲み文字がデータ中に入っている場合について
Oracle
-
7
変数が選択リストにありません
Oracle
-
8
Oracleのデータ型、NUMBERについて
その他(データベース)
-
9
PL/SQLでのSQL文法
その他(データベース)
-
10
update文で改行を入れる
Oracle
-
11
SELECTで1件のみ取得するには?
Oracle
-
12
日付型カラムへのデータINSERT
Oracle
-
13
Excelでcsvやtxtで保存する時にダブルクォートが勝手に付く
Excel(エクセル)
-
14
列名XXXXが無効です
SQL Server
-
15
count関数の値をwhere句で使用する方法について
MySQL
-
16
カラム位置変更
Oracle
-
17
CASE文のエラーについて
Oracle
-
18
ORA-01843: 指定した月が無効です。エラー
Oracle
-
19
ORA-01858: 数値を指定する箇所に数値以外の文字が指定されています
Java
-
20
DATE型にNULLをセットするには?
Oracle
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ハッシュテーブル(連想配列)が...
-
PysimpleGUIでデータベースを作る
-
power BI クエリエディター 〇...
-
VBA 違うシートにコピペしてソ...
-
rand関数の割合変更
-
テキストボックスのvalueとtext...
-
オペランド
-
VBA 「実行エラー”13” ...
-
ユーザーフォームのテキストボ...
-
aspx.csからJSON形式にする方法
-
OracleでRecordCountが正しくな...
-
値を返さないコード パス
-
マクロ 特定のセル値のみクリ...
-
形式(値だけ)を選択して貼り...
-
パスワードの再入力処理
-
VBでBtrieveファイルにアクセス...
-
VBのテキストボックスに値が...
-
pingを行うプログラム
-
C# get set
-
マクロで奇数と偶数の値を2か所...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
テキストボックスのvalueとtext...
-
マクロ 特定のセル値のみクリ...
-
VB.NETでコンボボックスの1行目...
-
変数名の取得
-
値を返さないコード パス
-
Excel VBAのリストボックスの値...
-
VB初心者。小数点以下の表示で...
-
ハッシュテーブル(連想配列)が...
-
textboxとLabelを動的に変更する
-
PL/SQLでのTO_DATEの時間取得に...
-
VB.NETでアクティブなformを知...
-
Excel vba ユーザーフォームテ...
-
マクロで奇数と偶数の値を2か所...
-
DataTableに対するLINQについて
-
【C++/CLI.NET】コンボボックス...
-
[VBA]選択範囲の下から上に処理...
-
範囲が指定されている乱数について
-
[VB.net] DataGridViewのコンボ...
-
変数に代入してある数値を表示...
-
vbscriptを使いexcelを参照して...
おすすめ情報