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

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

ただいまの
回答率

90.53%

  • MySQL

    5836questions

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

MySQLのパーティショニングについて

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 67

nnahito

score 1706

 考えていること

Twitterのつぶやきのような、大量のデータの素早い検索について。

 MySQLとパーティショニング

例えば、MySQLのパーティショニングの散布で、日付でパーティションを作成する例をよく見ますが、
この場合「Twitterのユーザのつぶやき数をすべてカウント」などになると、結局総なめになるかと思います。

このとき、例えば「ユーザIDにパーティションを作成する」というアプローチは正しいのでしょうか?
こうすると、ユーザIDをwhere区に入れると、
そのユーザのつぶやきを取得するのにパーティションが効き、高速化ができそうなイメージです。

MySQLのパーティションに上限などあるのでしょうか?
軽くググったところそれらしきものはなさそうですし……
(まあDBの容量は食いますが……)

このアプローチのメリット・デメリットなど、ご教示いただけると幸いです。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

+1

この場合「Twitterのユーザのつぶやき数をすべてカウント」などになると、結局総なめになるかと思います。

その用途が頻繁にあるなら

ユーザIDにパーティションを作成する

こともありかと。
他の問い合わせの方が多くて、「ユーザのつぶやき数をすべてカウント」する需要が少なければ、パフォーマンスは悪くてもユーザID毎のパーティションは採用しないで、需要の多いSQLのパフォーマンスが良くなるようなパーティションを選択します。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/07/28 18:04

    ご回答有り難うございます!
    なるほど、このアプローチもありなのですね!
    勉強になります!!

    キャンセル

0

「Twitterのユーザのつぶやき数をすべてカウント」などになると、結局総なめになるかと思います。

インデックスがあれば、総なめにはなりませんよ。

パーティションというのは、マルチカラムインデックスとなるような場合に、そのカラムの一部でパーティションするものです。

普通、パーティションは、マルチカラムインデックスのうちカーディナリティの低いものに適用します。
ユーザーIDというのは、どのようなテーブルに含まれたにしろ、カーディナリティは高い部類です。

カーディナリティが高いならインデックスで十分です。

ユーザーIDのカーディナリティが他のカラムより低いのならば別ですが、余程特殊な用途でない限りあまりないのではないかと思います。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.53%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 解決済

    MySQLについて

    MySQLについて質問です。 MySQLにてテーブルを作成したところなのですが、テーブルを作成した際のCREATE文を拡張子sqlのファイルで提出してほしいといわれたのですが、メモ

  • 解決済

    APIの利用方法について

    前提・実現したいこと最近プログラミングを始めた者です。プログラミングの基礎の基礎が載っているような参考書を一通りやり終え、次は自作アプリを…!と意気込んでアプリを作り始めたのですが

  • 受付中

    データベース接続エラー

    データベースの状況を調べたくてログインしようとしてもできませんでした。 mysqlのユーザーネームとパスワードとホストネームを調べる方法を教えていただきたいです。 ワードプレス

  • 解決済

    アカウント毎にパーティションするという発想は有効ですか?

    こんばんは。 MySQLのパーティショニング機能ですが、以下のケースで有効に働くかどうか分かりません。 ・全てのテーブルを、ユーザーアカウント単位でHASH パーティショニ

  • 解決済

    MySQLにおいて、同一カラムから複数の値を外部結合して参照したい。

    外部結合してデータを参照する際、複数の同一カラムに複数の値を持たせて結合させたいのですが、どうすれば良いかわかりません。 例えば m_user ーーーーーーーーーーー

  • 受付中

    MySQL5.6でインデックス追加作業時のサーバ負荷について

    MySQL5.6.21で利用しているDBサーバで 1億レコードがあるテーブルのデータにオンラインでインデックスを追加する作業を考えています ステージング環境で検証すればいいので

  • 解決済

    mysqlでパーティションについて

    パーティションを張りたいのですがPARTITIONに指定するカラムってPRIMARYのカラムじゃないといけないのでしょうか。 下記のようなエラーが出たので意味合い的にPRIMARY

  • 解決済

    mysqlでのbetweenについて

    先日仕事中にbetweenはパーティションがきかないことがあったり、その人の過去の経験でmysqlの不具合でパーティションが削除されたことがあると言っていたのですが本当でしょうか?

同じタグがついた質問を見る

  • MySQL

    5836questions

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