一般的なアプリケーションでは、timestamp、datetime、int 型を使用して時間形式を保存します。 int (javaBean の Integer または int に相当) 1. 4バイトを占有する 2. インデックス作成後、クエリ速度が速くなる 3. 条件範囲検索は、 4. MySQLが提供する時間関数が使用できない 結論: 多数の時間範囲クエリを必要とするデータテーブルに適しています datetime (日付型は javaBean で使用されます) 1. 8バイトを占有する 2. 空の値を許可し、値をカスタマイズできますが、システムは値を自動的に変更しません。 3. 実際の形式のストレージ(保存したものを保存し、保存したものと同じものを取得します。) 4. TIMEZONE と変換を扱うものは何もありません。 5. デフォルト値を設定することはできないため、null 値が許可されていない場合は、データを正常に挿入するには、datetime フィールドの値を手動で指定する必要があります。 6. datetime フィールドの値を指定するときに、now() 変数を使用してシステムの現在の時刻を自動的に挿入できます。 結論: datetime 型は、レコード内の他のフィールドの値をどのように変更しても、手動で変更しない限り datetime フィールドの値は変更されないため、データの元の作成時刻を記録するのに適しています。 タイムスタンプ (JavaBean の日付またはタイムスタンプ型) 1. 4バイトを占有する 2. 空の値は許可されますが、カスタム値は許可されないため、空の値は意味を持ちません。 3. TIMESTAMP 値は 1970 年より前または 2037 年より後にすることはできません。つまり、「1968-01-01」などの日付は、DATETIME または DATE 値には有効ですが、TIMESTAMP 値には有効ではなく、そのようなオブジェクトに割り当てられると 0 に変換されます。 4. 値はUTC形式で保存されます(ミリ秒数を格納します) 5. タイムゾーン変換: 保存時に現在のタイムゾーンを変換し、取得時に現在のタイムゾーンに戻します。 6. デフォルト値は CURRENT_TIMESTAMP() で、これは実際には現在のシステム時刻です。 7. データベースは自動的に値を変更するため、レコードを挿入するときにタイムスタンプ フィールドの名前とタイムスタンプ フィールドの値を指定する必要はありません。テーブルを設計するときにタイムスタンプ フィールドを追加するだけで済みます。挿入後、フィールドの値は自動的に現在のシステム時間になります。 8. 将来いつでもテーブル内のレコードを変更すると、対応するレコードのタイムスタンプ値が現在のシステム時間に自動的に更新されます。 結論: タイムスタンプ型は、レコード内の他のフィールドの値を変更すると、タイムスタンプ フィールドの値が自動的に更新されるため、データの最終変更時刻を記録するのに適しています。 要約する 上記は、MySQL で時間と日付の型を保存する選択問題の分析に関するものです。興味のある方は、MySQL のステートメント サブクエリの効率最適化スキルの例、MYSQL サブクエリとネストされたクエリの最適化の例の分析、サブクエリの代わりに接続 (結合) を使用した MySQL の最適化などを参照してください。質問がある場合は、いつでもメッセージを残していただければ、編集者がすぐに返信します。これが皆さんのお役に立てば幸いです。 以下もご興味があるかもしれません:
|
>>: mysqlパラメータsql_safe_updatesを使用して更新/削除範囲を制限する方法の詳細な説明
昨日プロジェクトを書いていた時に、MySQL の派生版である Percona を使う必要があったので...
Tomcat サーバーは、無料でオープン ソースの Web アプリケーション サーバーです。軽量のア...
mysql5.7.21の簡単なインストール構成は次のとおりです。 1. MySQLのインストール1....
1. HTML マークアップ言語とは何ですか? HTML は、Web ページの情報を表すマークアッ...
目次1. 理論シリアル化可能繰り返し読み取りコミットされた読み取りコミットされていない読み取り2. ...
目次序文プロトタイプ継承アドバンテージ欠点コンストラクタの継承アドバンテージ欠点組み合わせ継承寄生的...
1. ESを使うこともあるリソースが限られている、またはビジネス上のニーズにより、最新の期間のデータ...
1. 埋め込みは違法です<embed> タグは Netscape のプライベート タグで...
目次1. Vueの初期化vue エントリ ファイルフルバージョンとランタイムバージョンの違い1.1、...
目次MySQL 8 の隠しインデックス、降順インデックス、関数インデックス1. 隠しインデックス1....
目次1. appIDの申請と設定1. appidの取得方法2. AppIDの設定2. 基本的なユーザ...
大規模な開発に Docker を使用する場合でも、クリーンアップ戦略がなければ、ディスクがすぐにいっ...
サーバーに複数のサイトを展開するには、異なるサイトにアクセスするために複数のポートを開く必要がありま...
このセクションでは、テキストの変更の詳細から始めます。これにより、読者はさまざまな HTML フォン...
目次1.ダウンロード後、インストールしたいディレクトリに解凍します。 2. インストールディレクトリ...