
お世話になります。SQL初心者です。
カラム 'entry_date'に string型で、
20120506072124123 といったような文字列が入っているとします。
これをdate型に変換したいです。
下記を中心に、CASTを使いながら、変換を色々と試したのですが、エラーがでてしまいます。
非常に基本的な質問で恐縮ですが、よろしくお願いいたします。
--
select CAST(entry_date AS datetime)
from
テーブル名
--
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答6件
0
ベストアンサー
SQL
1SELECT to_date(CONCAT(SUBSTRING(entry_date, 1, 4) , '-' 2 , SUBSTRING(entry_date, 5, 2) , '-' 3 , SUBSTRING(entry_date, 7, 2) , ' ' 4 , SUBSTRING(entry_date, 9, 2) , ':' 5 , SUBSTRING(entry_date, 11, 2) , ':' 6 , SUBSTRING(entry_date, 13, 2) , '.' 7 , SUBSTRING(entry_date, 15, 3)),'yyyy-mm-dd hh24:mi:ss.SSS') 8 9FROM (テーブル名) 10
DBによってSQLの書き方も違います。(同じ部分もあれば違う部分もある)
ということでDBがTreasureData ということで。
投稿2018/09/03 09:51
編集2018/09/03 12:01
退会済みユーザー
総合スコア0
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。

退会済みユーザー
2018/09/03 10:25
2018/09/03 10:33

退会済みユーザー
2018/09/03 10:34

退会済みユーザー
2018/09/03 10:54 編集

退会済みユーザー
2018/09/03 10:49
2018/09/03 10:57

退会済みユーザー
2018/09/03 11:33

退会済みユーザー
2018/09/03 11:46

退会済みユーザー
2018/09/03 12:36 編集

退会済みユーザー
2018/09/03 12:36

0
UNIX_TIMESTAMP()で書式を指定して変換します。
SQL
1SELECT UNIX_TIMESTAMP(entry_date, 'yyyyMMddHHmmssSSS') - 32400
投稿2018/09/04 01:11
総合スコア25354
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
0
フォーマットが決まっているなら頑張って文字列を組み立てればいいでしょう.
SQL
1SELECT CONVERT(datetime, CONCAT(SUBSTRING(entry_date, 1, 8), ' ', SUBSTRING(entry_date, 9, 2), ':', SUBSTRING(entry_date, 11, 2), ':', SUBSTRING(entry_date, 13,2), '.', SUBSTRING(entry_date, 15, 3)))
投稿2018/09/03 09:29
総合スコア13749
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
0
SQL
1SELECT CAST(SUBSTRING(entry_date, 1, 4) + '/' 2 + SUBSTRING(entry_date, 5, 2) + '/' 3 + SUBSTRING(entry_date, 7, 2) + ' ' 4 + SUBSTRING(entry_date, 9, 2) + ':' 5 + SUBSTRING(entry_date, 11, 2 ) + ':' 6 + SUBSTRING(entry_date, 13, 2) + '.' 7 + SUBSTRING(entry_date, 15, 3) AS DATETIME) 8 9FROM (テーブル名) 10
まあ文字列17バイトをデータベースは日付型とは認識していないのでね。
投稿2018/09/03 09:08

退会済みユーザー
総合スコア0
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。

退会済みユーザー
2018/09/03 09:44

退会済みユーザー
2018/09/03 10:11

0
検証してないのですが、SELECT dateadd(s,CAST(entry_date as bigint),'19700101 05:00:00:000');
な感じはどうでしょう。
entry_dateを数値の羅列ってだけでuinx秒だと思ってしまいました。取り下げます(相応しい回答が他にあるため、取り下げのみ)
投稿2018/09/03 08:52
編集2018/09/03 09:10総合スコア12705
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。

あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。