ホームページ >バックエンド開発 >PHPチュートリアル >投票プロジェクトを作成しましたが、投票するたびにデータベースにアクセスしたくないのですが、どのようにすればよいですか?
データベース遅延投票
投票プロジェクトを作成しましたが、投票するたびにデータベースにアクセスして更新したくありません。一定期間後にデータベースを更新するにはどうすればよいですか?投票後すぐにデータベースが更新されないと、表示される投票結果が正しくないのではありませんか?
リアルタイム機能、バッチで挿入する必要はありません。
投票後すぐにデータベースが更新されないと、表示される投票結果が正しくないのではないでしょうか? データベースは 1 分に 1 回更新されると思います
私が考えることができるより直接的な方法は次のとおりです:
形式は SQL ステートメント (推奨) または単純なデータのダンプです。
バックグラウンドで cron ジョブを実行し、ソフトウェアを毎分スキャンし、いくつかのマーカー (最後に処理された最大 ID、タイムスタンプなど) を使用して、データベースに更新する必要があるコンテンツをフィルターします。
投票結果をさまざまな期間の配列に保存し、その配列を一時ファイルに書き込み、このファイルを定期的に抽出し、その後このファイルをクリアすることができます。これは 4 階のアイデアと似ています。
キューを使用してください!これはとても便利ですし、データはリアルタイムで便利です~
memcache などのキャッシュを使用してみてはいかがでしょうか
時々バッチでデータベースを読み書きし、同時に memcache をクリアしてみてはいかがでしょうか?
bを作成し、テーブルbにデータを書き込み、時間をブロックして bのデータをaに更新します。
考え方は 4 5 7 階と似ています。保存する一時ファイルを作成し、必要なときにライブラリに読み込みます。
ファイルを書き込んでデータベースに保存します。
では、データベースは他に何に使用されるのでしょうか?
データベースに直接書き込むことをお勧めします
ファイルの同時実行は実際には扱いが難しいです
そして、ファイルとデータベースを読み取るという観点からは、データベースの方が便利だと思います
これがデータベースの機能です。あなたのこのプロジェクトは非常に小さなものです。
mysql メモリ テーブルはデータを処理します。
私が考えることができるより直接的な方法は次のとおりです:
投票結果をテキスト ファイルに書き込む。形式は SQL ステートメント (推奨) または単純なデータのダンプです。
バックグラウンドで cron ジョブを実行し、ソフトウェアを毎分スキャンし、いくつかのマーカー (最後に処理された最大 ID、タイムスタンプなど) を使用して、データベースに更新する必要があるコンテンツをフィルターします。
これは私がこのアイデアで行ったことです
さまざまな期間で投票結果を配列に保存し、その配列を一時ファイルに書き込み、このファイルを定期的に抽出し、ファイルをクリアすることができます。これは次のようなものです。 4階のアイデア!
時々ファイルを抽出するというのはどういう意味ですか? PHP プログラムはすべてトリガー後に実行されます。このファイルを時々自動的に抽出するにはどうすればよいですか?