ホームページ >バックエンド開発 >PHPチュートリアル >タイムスタンプ PHP タイムスタンプの使用例コード
私たちは必ずこのような状況に遭遇します。銀行 A と銀行 B がほぼ同時にあなたの口座を開設し、あなたの口座に元の預金が 1,000 元あるのを確認し、その後、両銀行があなたの口座に 500 元の預金を追加したいと考えています。次に、銀行 A が 1,000 元を 1,500 元に変更し、同時に銀行 B も 1,000 元を 1,500 元に変更します。それは良くないね!結局、銀行口座にあるはずの 2,000 元が 1,500 元しか残らないことになり、これは 500 元の損失に相当します。ここで、データをロックせずに変更すると重大な問題が発生します。ただし、この問題はタイムスタンプを使用することでうまく解決できます。
アイデアを見てみましょう:
銀行口座テーブルにタイムスタンプ フィールド timestamp を作成し、それをテキスト タイプ varchar に設定します。
銀行 A が口座テーブルの預金フィールドを読み取るとき、123456 などのタイムスタンプ フィールドも読み取ります。
銀行 A が預金額を変更して保存操作を実行すると、以前に読み取られたタイムスタンプ 123456 と現在のテーブルのタイムスタンプが比較され、それらが一致する場合、保存が許可され、456789 などの新しいタイムスタンプが生成されます。テーブル内の元のタイムスタンプ 123456。
これによりどのようなメリットが得られますか?
最初の状況を見てみましょう。銀行 A と銀行 B がほぼ同時にあなたの口座を開設し、あなたの口座に元の預金が 1,000 元あることを確認しました。同時に、2 つの銀行はタイムスタンプ 123456 を同時に読み取りました。次へ 違いがあります。銀行 A が 1,000 元を 1,500 元に変更してディスクを保存すると、システムは前のタイムスタンプ 123456 を比較して、保存時にテーブル内のタイムスタンプと一致するかどうかを確認します。現在は一貫性があるため、保存が許可され、古いタイムスタンプ 123456 を置き換えるために新しいタイムスタンプ 456789 が生成されます。次に、銀行 B も 1,000 元を 1,500 元に変更して保存しました。システムは、保存時にテーブル内のタイムスタンプと一致するかどうかを確認するために、以前のタイムスタンプ 123456 を比較しました。その結果、以前のタイムスタンプ 123456 が現在のタイムスタンプとは異なることがわかりました。 456789。システムは保存を拒否し、データの更新が必要になります。その後、銀行 A が以前に 500 元を入金したため、1,000 元が 1,500 元になり、銀行 B は 1,500 元を 2,000 元に変更して再度保存します。 . システムがそれを許可します。このようにして、データの繰り返し変更によって引き起こされるエラーを回避します。
ちょっと早口言葉のようなものですが、皆さんに私の言いたいことを理解していただければ幸いです~
最後に、PHP のタイムスタンプのオペレーション コードをいくつか見てみましょう。
タイムスタンプを取得
$timestamp=time();
echo $timestamp;
SQLステートメント:
update table name set field name=$timestamp wherecondition=value; Sunec
原文: Cenus Blog
無断複写・転載を禁じます。転載する場合は、著者、出典、およびこの記述をリンクの形式で表示する必要があります。
上記は、タイムスタンプの内容を含む、タイムスタンプ PHP の使用例コードを紹介しています。PHP チュートリアルに興味のある友人に役立つことを願っています。