技術コミュニケーション室 OSSグループの髙﨑です。 当グループでは、マストドンというオープンソースの分散型マイクロブログについて、 弊社が運営するインスタンス「friends.nico」の運営、独自機能の開発、運用、ならびにそれらで得た知見を上流のプレーンなマストドンへcontributeするという業務を主に行っています。 本記事では、tableに適切なindexを張ることによってとあるスロークエリの速度改善を行った事例について、実際に上流へ行ったPullRequestをベースにお話させていただきます。 内容としては反面教師とするべき失敗例を伴った、非常に基礎的なPostgreSQLの実行計画の読み方ならびにクエリに合わせたindexの張り方です。 また、表題の2万倍速というのは改善前の最悪の場合比であり嘘ではないものの、通常問い合わせされる範囲の条件ではだいたい3〜30倍速であるという
![とあるクエリを2万倍速にした話 -データベースの気持ちになる- 前編 - dwango on GitHub](https://cdn-ak-scissors.b.st-hatena.com/image/square/50a8c8c65c1b0cccdbdf702f4d56894be97b78d0/height=288;version=1;width=512/https%3A%2F%2Fdwango.github.io%2Fimages%2Flogo.png)