MySQL には 3 つの日付型があります。日付(年-月-日) テーブル test(hiredate date) を作成します。 datetime (datetime 型) テーブル test(hiredate datetime) を作成します。 タイムスタンプ(消印タイプ、年月日時分秒を保存) テーブル test(hiredate タイムスタンプ) を作成します 日付時刻とタイムスタンプの違い1. 両者の保管方法は異なるTIMESTAMP の場合、クライアントによって挿入された時間を現在のタイムゾーンから UTC (協定世界時) に変換して保存します。クエリを実行すると、クライアントの現在のタイムゾーンに変換されて返されます。 DATETIME の場合は変更はなく、基本的にそのまま入力・出力されます。 2. 両者で保存できる時間範囲が異なるタイムスタンプが保存できる時間の範囲は、「1970-01-01 00:00:01.000000」から「2038-01-19 03:14:07.999999」です。 datetime が保存できる時間の範囲は、「1000-01-01 00:00:00.000000」から「9999-12-31 23:59:59.999999」です。 要約: TIMESTAMP と DATETIME は、保存範囲と保存方法を除いて大きな違いはありません。もちろん、タイムゾーンをまたぐビジネスには TIMESTAMP の方が適しています。 3. 自動初期化と更新自動初期化とは、フィールドに明示的な割り当てがない場合 (上記の例の hiredate フィールドなど)、現在のシステム時刻に自動的に設定されることを意味します。 自動更新とは、他のフィールドが変更された場合、このフィールドの値が現在のシステム時間に自動的に更新されることを意味します。 これは、「explicit_defaults_for_timestamp」パラメータに関連しています。 デフォルトでは、このパラメータの値はOFFです。 mysql> '%explicit_defaults_for_timestamp%' のような変数を表示します。 +---------------------------------+-------+ | 変数名 | 値 | +---------------------------------+-------+ | タイムスタンプの明示的なデフォルト | オフ | +---------------------------------+-------+ セット内の行数 (0.00 秒) 要約: timestamp は自動的に初期化され、更新されます。レコードを更新すると、列の値も自動的に更新されます。これが datatime との最大の違いです。 補足: DATETIME と TIMESTAMP の違いと問題点 今日、問題が発生しました。データは更新されましたが、update_time フィールドはデータが作成された時点のままでした。 通常、このフィールドは自動的に更新されます。 テーブル構造を確認しました。 `update_time` 日時 NOT NULL DEFAULT CURRENT_TIMESTAMP update_timeフィールドの型がdatetimeであることが判明しました これによって2つの疑問が生じます: (1) タイムスタンプと日付時刻の違い (2) なぜCURRENT_TIMESTAMPが日付時刻型に使用できるのか タイムスタンプと日付時刻の違いa) DATETIME のデフォルト値は null です。TIMESTAMP フィールドのデフォルト値は null 以外 (not null) であり、デフォルト値は現在時刻 (CURRENT_TIMESTAMP) です。特別な処理が行われず、更新ステートメントで列の更新値が指定されていない場合、デフォルトの更新は現在時刻です。 この違いは、通常はタイムスタンプを使用するため、このフィールドを自動的に更新するように管理する必要がない理由を説明しています。ここでは datetime を使用しており、現在の時刻を自動的に更新するメカニズムがないため、上位層でこのフィールドを手動で更新する必要があります。 b) DATETIME は 8 バイトのストレージ スペースを使用し、TIMESTAMP は 4 バイトのストレージ スペースを使用します。したがって、TIMESTAMP は DATETIME よりもスペース効率が高くなります。 この違いにより、タイムスタンプ タイプがより頻繁に使用される理由が説明されます。c)両者の保存方法は異なります。TIMESTAMP の場合、クライアントが挿入した時刻を現在のタイムゾーンから UTC (協定世界時) に変換して保存します。クエリを実行すると、クライアントの現在のタイムゾーンに変換されて返されます。 DATETIME の場合は変更はなく、基本的にそのまま入力・出力されます。 d)保存できる時間範囲が異なる タイムスタンプが保存できる時間の範囲は、「1970-01-01 00:00:01.000000」から「2038-01-19 03:14:07.999999」です。 datetime が保存できる時間の範囲は、「1000-01-01 00:00:00.000000」から「9999-12-31 23:59:59.999999」です。 CURRENT_TIMESTAMP を datetime 型に使用できるのはなぜですか? MySQL 5.6 より前のバージョンでは、CURRENT_TIMESTAMP はタイムスタンプ型にのみ使用できます。 バージョン5.6以降では、CURRENT_TIMESTAMPもdatetime型に使用できます。 select version() でデータベースをチェックしたところ、バージョンは 5.6.29 であることがわかりました。 上記は私の個人的な経験です。参考になれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。間違いや不備な点がありましたら、遠慮なくご指摘ください。 以下もご興味があるかもしれません:
|
目次1. 事前分析1. 変数の事前解析と関数の事前解析1. 変数の事前解析2. 機能事前分析2. 事...
MyISAM ストレージエンジンMyISAM は ISAM ストレージ エンジンに基づいており、それ...
VMware の準備 CentOS の準備、こちらは CentOS 7.3 CentOS-7-x86...
CSSは複数のクラスにマッチする次の HTML タグ li、クラスはオープン スタイルです。私の要件...
序文Nginx はパフォーマンスを重視して設計された HTTP サーバーです。Apache や li...
目次ツリー項目にコードを追加します。 1. 右側に関連情報ページを保存します(userManage....
商品を検索するときに、すべてのブランドまたは一部のブランドを表示するTaobaoの機能を真似してみま...
アプリケーションをコンテナ化した後、Docker コンテナを起動すると、デフォルトで root ユー...
個人的な実装のスクリーンショット:インストール: npm インストール vue-esign --sa...
メタ属性には、name と http-equiv の 2 つがあります。 name 属性は主に、We...
HTML徹底解析(14)特殊文字 ■ よく使われる特殊文字 HTMLタグを知っていれば、特殊文字の使...
【序文】 ORM を使用してデータベース内のデータを操作する場合、前提として、新しい ORM モデル...
目次1. プロキシとは何ですか? 2. 使い方は? 1. プロキシを使用する簡単な例2. 対象オブジ...
目次1. 実施プロセス2. オブザーバーを表示する3. ウォッチャーを実装する4. コンパイルを実装...
目次序文文章1. stylelintをインストールする2. 設定ファイル3. stylelintを使...