質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

0回答

438閲覧

コメントランキングのDB設計において、閲覧・更新タイミングのズレを修正したい

ikatako

総合スコア270

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2020/11/12 20:46

###実現したいこと
Youtubeにあるように、無限ロードでの「コメントの人気順ソート」をMySQLにて実装したいです。

「誰がいつどのコメントへ」は評価のたびにINSERTされますが、「その集計とランク付け」は毎時間のUPDATEとするつもりです。

しかし閲覧と集計の時刻によって読み込みがズレる問題を想定しており、解決方法についてアドバイスを頂戴したく存じます。

###例
例えば以下の評価テーブルa_upsa_downsもありますが割愛します)と、コメントテーブル(p_comments)があり、コメントテーブルは集計結果としてpopular_orderカラムに値が入った状態を考えます。

●評価テーブルa_ups

IDuser_IDcomment_IDcreated_at
110012020/01/02 12:00:01
220032020/01/02 12:00:02
310022020/01/02 12:00:03
430032020/01/02 12:00:04


↓ 上記を毎時間集計し、popular_orderカラムを更新する
comment_ID=3が最多で2件の評価を得ているのでpopular_orderカラムは1位の1が入る

●コメントテーブル(p_comments

IDcommentpopular_ordercreated_at
1かっこいいね22020/01/01 12:00:01
2かわいいね32020/01/01 12:00:02
3素敵だね12020/01/01 12:00:03
4きれいだね42020/01/01 12:00:04

###想定している問題
閲覧の最中に集計された場合、「閲覧開始時のコメント順序」と「集計後のコメント順序」が変化してしまい困ります。

まずコメントは2件ずつ無限ロードされ、ORDER BY popular_order DESCでソートすると考えまして、

1回目は
comment_ID=2「素敵だね」
comment_ID=3「かっこいいいね」
が読まれ

そして2回目は
comment_ID=1「かわいいね」
comment_ID=4「きれいだね」
と続くハズなわけですが、

もし2回目の無限ロードが集計以後に実行された場合、かつ集計によってpopular_orderの値が1回目から変化した場合にコメント順序ズレてしまうと気づきまして…

###考えている解決策
この問題の解決策として以下を考えましたが、微妙な印象です。

まず毎時間の更新履歴を、popular_order_1,popular_order_2,popular_order_3,,,と24個のカラムで一日分p_commentsに持たせておき、POSTされた閲覧開始時刻にあったpopular_order_●でソートします。

これならソート対象のカラムは閲覧開示時刻に基づくため、24時間以内なら集計が起こっても平気です。
1時に閲覧開始した人は、無限ロードの実行が2時でも3時でもpopular_order_1でソートするわけです。

●コメントテーブル(p_comments

IDcommentcreated_atpopular_order_1popular_order_2popular_order_3
1かっこいいね2020/01/01 12:00:01233
2かわいいね2020/01/01 12:00:02324
3素敵だね2020/01/01 12:00:03112
4きれいだね2020/01/01 12:00:04441

そしてもし閲覧開始時刻が24時間以上前の場合、コメントはレスポンスせずJSで強制的にページリロードさせ、無限ロードをリセットしてしまうという方法です。

これが自分の中での解決策なのですが、いかがでしょうか。

より良い方法やアドバイスなど頂戴できましたら幸いです。
宜しくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hentaiman

2020/11/12 23:46

より良い方法の「より良い」の定義は? ・更新完了するまで該当データを使わない ・更新完了するまでキャッシュを使う ・更新と同時にテーブルをリネームして入れ替える それぞれ視点によってはメリット・デメリットが変わる訳です。 ※どれがどんなメリットですか?とコメントされてもスルーしますが、これのメリット・デメリットはこういう事ですか?という疑問になら追加返答するかもしれません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問