![](https://cdn-ak-scissors.b.st-hatena.com/image/square/7160d4babd4d555f02977d7dd74f94d47b2f7570/height=288;version=1;width=512/https%3A%2F%2Fqsf.cf2.quoracdn.net%2F-4-images.social_share_brand_logo.png-26-b6922c34f079ee95.png)
Qiitaには編集リクエスト採用時にコンフリクト機能がついていますが、このシステムはどのようなDB設計で実現できますか? 編集履歴保存だけではdiff表示は出来てもコンフリクト機能は作れなそうですが。
エントリーの編集
![loading...](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/common/loading@2x.gif)
エントリーの編集は全ユーザーに共通の機能です。
必ずガイドラインを一読の上ご利用ください。
Qiitaには編集リクエスト採用時にコンフリクト機能がついていますが、このシステムはどのようなDB設計で実現できますか? 編集履歴保存だけではdiff表示は出来てもコンフリクト機能は作れなそうですが。
記事へのコメント0件
- 注目コメント
- 新着コメント
このエントリーにコメントしてみましょう。
注目コメント算出アルゴリズムの一部にLINEヤフー株式会社の「建設的コメント順位付けモデルAPI」を使用しています
![アプリのスクリーンショット](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/entry/app-screenshot.png)
- バナー広告なし
- ミュート機能あり
- ダークモード搭載
関連記事
Qiitaには編集リクエスト採用時にコンフリクト機能がついていますが、このシステムはどのようなDB設計で実現できますか? 編集履歴保存だけではdiff表示は出来てもコンフリクト機能は作れなそうですが。
回答 (3件中の1件目) 一般的に、コンフリクトの検出には最低3つの版が必要になるはずです。 1. 現在の最... 回答 (3件中の1件目) 一般的に、コンフリクトの検出には最低3つの版が必要になるはずです。 1. 現在の最新版 2. 編集リクエストにより作られた新しい版 3. 編集リクエストが元にした版 1と2は、それぞれ3から何かしらの変更を加えたものになります。なので、3は1や2よりも古い版になります。 3と1の差分をA、3と2の差分をBとします。行単位の検出であれば、AとBに同一行に対する変更があったかどうかを調べます。もし変更があれば、それが同一の変更でなければ、コンフリクトが発生したことになります。 3を保持するには、過去すべての履歴を保存しておくべきです。が、編集リクエストが可能な...