ホームページ >データベース >mysql チュートリアル >MySQL の特定の範囲内にランダムな日時を挿入するにはどうすればよいですか?

MySQL の特定の範囲内にランダムな日時を挿入するにはどうすればよいですか?

DDD
DDDオリジナル
2025-01-01 03:22:09951ブラウズ

How to Insert Random Datetimes Within a Specific Range in MySQL?

MySQL での範囲内のランダムな日時値の挿入

SQL を使用して、指定された範囲内にランダムな日時値を挿入するのは困難な場合があります。 「2010-04-30 14:53:27」から「2012-04-30 14:53:27」などの範囲を指定すると、その範囲内に値を正確に挿入すると混乱を招く可能性があります。

解決策:

指定された範囲内でランダムな日時値を挿入するには、次のコマンドを使用します。アプローチ:

INSERT INTO `sometable` VALUES(
    FROM_UNIXTIME(
        UNIX_TIMESTAMP('2010-04-30 14:53:27') 
        + FLOOR(0 + (RAND() * 63072000))
    )
)

説明:

  • UNIX_TIMESTAMP() 関数は、基準日時 (「2010-04-30 14:53: 27") を Unix タイムスタンプに変換します。
  • RAND() は生成します。 0 から 1 までのランダムな浮動小数点数。
  • 63072000 は 2 年間の秒数です (または 60 60 24 365 2)。
  • FLOOR() は、生成された乱数を最も近い値に切り捨てます。 integer.
  • 結果の値は、2 年の範囲内のランダムな秒数を表す基本 Unix タイムスタンプに追加されます。
  • FROM_UNIXTIME() は、変更された Unix タイムスタンプを DATETIME に変換します。 .

このアプローチはかなり正確ですが、長期間にわたってリープなどの要因が発生することに注意する必要があります。年により、正確な範囲から若干の誤差が生じる可能性があります。

以上がMySQL の特定の範囲内にランダムな日時を挿入するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。