MySQL タイムスタンプ精度の制限と回避策
MySQL ではミリ秒とマイクロ秒の精度がサポートされていないことが開発者にとって長年の問題であり、正確なタイムスタンプを妨げています。アプリケーションで。この制限は、TIMESTAMP フィールドとそのサポート関数に影響します。
回避策: BIGINT フィールド
回避策の 1 つは、BIGINT フィールドを使用してタイムスタンプを保存することです。ただし、精度を確保するには、アプリケーションによる慎重な取り扱いが必要です。人気の PHP オブジェクト リレーショナル マッピング ライブラリである Doctrine は、フィールドにミリ秒を自動的に追加したり、日付操作関数を処理したりできない場合があります。
回避策: UDF 拡張機能
UDF のコンパイル拡張機能を使用するとマイクロ秒の精度を実現できますが、持続可能なソリューションではありません。データベースのアップグレードまたは変更により、拡張機能が削除される可能性があります。
MySQL バージョンの更新
幸いなことに、この制限は MySQL バージョン 5.6.4 で解決されています。 TIME、DATETIME、TIMESTAMP 値の小数秒を最大マイクロ秒精度でサポートするようになりました。このアップデートは、正確なタイムスタンプを必要とするアプリケーションに決定的なソリューションを提供します。
結論
MySQL の以前のミリ秒とマイクロ秒の精度の不足は、バージョン 5.6.4 で解決されました。以前のバージョンを実行している環境の場合、開発者は BIGINT フィールドの回避策を検討する必要がある場合がありますが、きめ細かいタイムスタンプを完全にサポートするには、バージョン 5.6.4 以降にアップグレードすることをお勧めします。
以上がMySQL タイムスタンプでミリ秒およびマイクロ秒の精度を達成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。