現在サーバー初心者なのでやり方がわかりません
例えば、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のデータを参照して、彼らはこの部分も削除しました、そして私たちは彼女がクリックできるようにまだ残しました。 。