サーバーの差分(増分)更新について
現在サーバー初心者なのでやり方がわかりません
例えば、2人のユーザーの場合、現在10個のサーバーデータがあり、AとBの両方が更新されています
しばらくすると、サーバーが更新され、データが 10 から 15 に増加しました
A が更新され、アプリのローカル データが 10 から 15 に変更されましたが、B は更新されず、まだ 10 でした。その間、サーバーのデータが再び更新され、データは 15 から 20 記事に増加しました
それでは、A には更新された 5 項目 (15 から 20) のみを追加させ、B には 10 項目 (10 から 20) を更新させるにはどうすればよいでしょうか20)?
ディスカッションに返信(解決策)
自分でやります
現在のデータのシリアル番号(ここではIDを使用します)の最大値をアプリに渡し、アプリが記録します
最初はAとBが同時に更新され、両方とも10です
更新時にデータのシリアル番号(ここではIDを使用します)がサーバーに送信されます。サーバーは select * from XXX where id >= クエリするアプリのローカル データ シリアル番号
A が更新されると (10 から 15)、現在の ID は 15 であり、B は更新されずに 10 のままです。同様に、サーバーは 16 から 20 のみを A に送信します 11 から 20 までのデータについては、サーバー B は増分更新を送信します
単純なロジック (データの追加のみ) の場合、上記の部分は次のようになります解決しました
しかし、ここで新たな問題が発生します。サーバーデータが変更されているか、削除対象としてマークされていますか?何をするか?
次に、次の処理を見る必要があります:
新しいフィールドマークを追加し、最初は0に設定します
AとBは最初に同時に更新され(両方とも10個のデータを更新しました)、すべての0 のマークが付いたフィールドは更新されます。ローカル マークは 0 です。
次に、テーブル内のデータを更新し (10 から 15)、その中のデータを変更し (項目 3)、項目 5 (としてマークされています) を削除します。 -1); 現在サーバー 10 から 15 までマークされたデータ マークは 1 です (1 から 10 までのものは 0 のままです)
A が更新され (10 から 15)、彼のローカル マークは 1 になりました。 ; B はローカル マークを更新せず、まだ 0 です
サーバーのデータは再度更新されます (15 から 20)
このとき、A と B は両方とも 1 としてサーバーに送信されます。 、サーバーはマークより大きいマーク (15 ~ 20 個のデータ) を探して A に送信します。同様に、0 より大きいマークを持つマーク (10 ~ 20 個のデータ) を B に送信することもできます。差分更新
それでは上記を見てみましょう。データが変更された場合はどうすればよいでしょうか?
上記のサーバーが 3 番目のデータを変更する場合、アプリが mark+2 に遭遇すると、このデータを更新し、特にクライアントを更新する必要があることに同意します。削除の同じマークの場合、-1 に同意します。これは、マークが表示されないことを意味します
ここで問題が再び発生します
サーバーの現在のマークが 5000 に達している場合、アプリは更新されていません。まだ 0 (同様の状況が新しくインストールされたクライアントにも当てはまります); その場合、同時に 5000 に更新する必要があります (数十万のデータがある可能性があります)。どうすればよいでしょうか?
そこで、制限を追加する必要があります。アプリがローカル マークをアップロードするとき、サーバーはそのマークとサーバー内の最大のマークの差が 50 を超えていると判断し、最大値のみを送信すると仮定します。 50 個のデータ (ここでは 4950 ~ 5000 個のデータ列を使用) なので、クライアントへの負担が軽減されます
それでは、期間中のデータをどうすればよいのかという疑問が生じるかもしれません。
破棄することを好みます。 。 2 番目のオプションは、この部分を処理するために小さいバージョンを選択することです。
しかし、WeChatとQQのデータを参照して、彼らはこの部分も削除しました、そして私たちは彼女がクリックできるようにまだ残しました。 。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











多くの場合、キーワードと追跡パラメーターで散らかった長いURLは、訪問者を阻止できます。 URL短縮スクリプトはソリューションを提供し、ソーシャルメディアやその他のプラットフォームに最適な簡潔なリンクを作成します。 これらのスクリプトは、個々のWebサイトにとって価値があります

2012年のFacebookによる有名な買収に続いて、Instagramはサードパーティの使用のために2セットのAPIを採用しました。これらはInstagramグラフAPIとInstagram Basic Display APIです。

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

これは、LaravelバックエンドとのReactアプリケーションの構築に関するシリーズの2番目と最終部分です。シリーズの最初の部分では、基本的な製品上場アプリケーションのためにLaravelを使用してRESTFUL APIを作成しました。このチュートリアルでは、開発者になります

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

2025 PHP Landscape Surveyは、現在のPHP開発動向を調査しています。 開発者や企業に洞察を提供することを目的とした、フレームワークの使用、展開方法、および課題を調査します。 この調査では、現代のPHP Versioの成長が予想されています
