お世話になります。
データベースのデータ型にはdatetimeがあります。これに必要な記憶領域は8バイトになるかと思いますが、フォーマットは「yyyy/mm/dd hh:nn:ss」であることが多いと思います。単純に文字列で考えると、サイズが足りないと思うのですがどういう仕組みなのでしょうか。
よろしくお願いいたします。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答4件
0
サイズが足りないと思うのですがどういう仕組みなのでしょうか。
文字列として格納されているわけではないからです。SQL Server の datetime 型の場合ですが:
"datetime データ型の値は、SQL Server 2005 データベース エンジンにより、内部的には 2 つの 4 バイトの整数として格納されます。最初の 4 バイトは基準日、つまり 1900 年 1 月 1 日からの日数、またはこの日までの日数を格納します。基準日とは、システムが参照する日付です。残りの 4 バイトは、午前 0 時から数えた 1/300 秒単位の数として表された時間を格納します。"
ということで、「yyyy/mm/dd hh:nn:ss」というような形式の文字列ではないのです。
投稿2017/12/12 03:13
退会済みユーザー
総合スコア0
0
んーと、まぁざっくばらんに言うと、内部的には最低単位(yyyy/mm/dd hh:nn:ssの場合、秒)だけで表される整数ですね。
投稿2017/12/12 03:04
編集2017/12/12 03:05退会済みユーザー
総合スコア0
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2017/12/12 03:11
退会済みユーザー
2017/12/12 03:17
退会済みユーザー
2017/12/12 03:17
退会済みユーザー
2017/12/12 03:18
0
すでに解決されていますが、色々なDBでの日時型についてまとまったページがありましたので紹介しておきます。
グレゴリオ暦?ユリウス暦? データベースによって異なる、日付時刻型が扱える範囲
意外とDB毎にバラバラだったり、1DB内の日時型でも複数もっていたり(datetimeとdatetime2型など)と奥深いです。
ちなみに0001/01/01 00:00:00
~9999/12/31 24:00:00
までの秒数単位で表すなら
ざっくり10000*12*31*24*60*60 = 321408000000 = 約5[byte]
で収まりますね。
投稿2017/12/12 04:09
総合スコア38262
0
ベストアンサー
こんにちは。
- Oracle Databaseの場合です。DATE型はdatetime型と同じです。
https://www.shift-the-oracle.com/element/data-type/data-type-inside.html
- SQLServerの場合です。
http://keicode.com/db/mssql06.php
他にも"DB名 datetime 内部表現"などとググると出てくると思います。
投稿2017/12/12 02:58
総合スコア728
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/12/12 04:20