MySQL は、日付と時刻を処理するために、DATETIME と TIMESTAMP という 2 つの非常によく似た型を提供しています。ほとんどの場合、どちらも問題ありませんが、場合によっては、それぞれに長所と短所があります。 日時DATETIME は、1001 から 9999 までのより広い時間範囲を持ち、精度は秒単位です。保存形式は、日付と時刻をパッケージ化し、YYYYMMDDhhmmss 形式の整数として保存します。この時間はタイムゾーンに依存せず、8 バイトのストレージ スペースを占有します。デフォルトでは、MySQL は DATETIME を 2021-06-02 18:35:23 などの順序付けられた明確な形式で表示します。これは ANSI 標準の日付と時刻の形式です。 タイムスタンプTIMESTAMP は、1970 年 1 月 1 日の午前 0 時からのグリニッジ標準時 (GMT) からの秒数を保存するタイムスタンプです。 Unix システムのタイムスタンプと同じです。 TIMESTAMP は保存に 4 バイトしか必要としないため、1970 年から 2038 年までのより短い時間範囲を表すことができます。 MySQL は、タイムスタンプと日付間の変換を完了するための FROM_UNIXTIME および UNIX_TIMESTAMP 関数を提供します。 MySQL バージョン 4.1 以降では、TIMESTAMP で表示される形式は DATETIME に似ていますが、TIMESTAMP の表示はタイム ゾーンによって異なります。 MySQL サーバー、オペレーティング システム、およびクライアント接続にはすべてタイム ゾーン設定があります。したがって、複数のタイムゾーンの時刻が保存されている場合、TIMESTAMP と DATETIME の差は大きくなる可能性があります。 TIMESTAMP は使用時にタイムゾーン情報を保持しますが、DATETIME は単にテキストを使用して時間を表します。 TIMESTAMP には追加機能があります。デフォルトでは、MySQL は、値が指定されていない場合は現在の時刻を使用して TIMESTAMP 列に挿入し、更新中に値が指定されていない場合は現在の時刻を使用してフィールドを更新します。次のテスト テーブルを例に挙げます。 テーブルt_time_testを作成します( id INT 主キー、 t_stamp タイムスタンプ、 t_datetime 日付時刻 ); MySQL によって指定されるデフォルト値は現在のタイムスタンプ CURRENT_TIMESTAMP であり、それに応じて更新されることを示す ON UPDATE CURRENT_TIMESTAMP があることがわかります。 t_time_test(id, t_datetime) に値を挿入する (1, NULL)、 (2, '2021-06-02 18:48:04'), (3、NULL); t_stamp 列に現在の時刻が自動的に入力されていることがわかります。 この機能により、IoT プログラムを通じてデータ更新時間フィールドを維持し、MySQL で完了させることができます。 選び方特性の観点から見ると、時間を保存するには DATETIME よりも効率的な TIMESTAMP の方が適している可能性があります。 Unix タイムスタンプを保存するために整数を使用する人もいますが、このアプローチには利点がなく、整数には追加の処理が必要になるため、お勧めできません。ただし、TIMESTAMP を使用して時間を保存しないように注意する必要がある状況がいくつかあります。
ミリ秒の時間を保存する方法通常、BIGINT を使用して時間を整数に変換して保存するか、浮動小数点数を使用して小数部分で 1 秒未満の精度で時間を表す必要があります。どちらの方法も実行可能です。もちろん、この時点では、フォーマット変換を行うにはアプリケーションのサポートが必要です。 結論安全性やセキュリティの観点から、DATETIME型を優先することをお勧めします。TIMESTAMPに比べてパフォーマンスが少し犠牲になりますが、TIMESTAMPの時間範囲は欠陥です。隠れた危険を放置しないでください。2038年になると、あなたの会社は上場企業になっている可能性があり、プログラマーは原因がわからないバグの洪水に遭遇し、会社の株価が急落する可能性があります。そして、このプログラマーを探し出し、彼が会社の元大物であり、現在の株主であり、そしてあなたが経済的自由を達成した人であることを知ってください。恥ずかしいと思いませんか? 上記はMySQLの時間タイプの選択の詳細です。MySQLの時間タイプの詳細については、123WORDPRESS.COMの他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
<<: 見落とされがちなMETAタグの特殊効果(ページ遷移効果)
目次ライフサイクル関数一般的なライフサイクルフックVue のインスタンス破棄について:要約するライフ...
フィルター属性は要素の視覚効果を定義しますぼかし画像にガウスぼかしを適用します。 「半径」の値は、ガ...
この記事は、4G メモリ システム用の MySQL 構成ファイル ソリューションです (主に Inn...
GROUP BY 句と HAVING 句を紹介する前に、まず SQL 言語の特殊な関数である集計関数...
この記事では、divのドラッグ可能な高さを実現するためのVueの具体的なコードを参考までに共有します...
1) プロセス 2) FSImageと編集NodeNode は HDFS の頭脳です。ファイルシステ...
QQtabBar の BEMまず、BEMとはどういう意味でしょうか? BEM は、ブロック、要素、修...
今日、新しい技を学びました。あまりやったことがなかったので、今まで知りませんでした...目的: リン...
<br /> 第 1 部と第 2 部では、Web サイトのパフォーマンス、ページ コンテ...
目次間違い1: データの列が多すぎる誤解2: 共同クエリが多すぎる誤解3: ENUMの代わりにSET...
1. はじめに外部キー制約を使用するかどうかという話題は、すでに決まり文句になっています。学校では、...
目次SaltstackがZabbixサービスを導入httpd、mysql、phpをインストールするh...
1. 公式サイトからダウンロード: https://dev.mysql.com/downloads/...
序文ご存知のとおり、「CSS で要素を垂直方向に中央揃えするにはどうすればよいか」という質問は、すで...
最近、同社は、下図に示すように、h5 ページ操作を完了するという要件を提示しました。 ネットで入手で...