SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

EnterpriseZine(エンタープライズジン)編集部では、情報システム担当、セキュリティ担当の方々向けに、EnterpriseZine Day、Security Online Day、DataTechという、3つのイベントを開催しております。それぞれ編集部独自の切り口で、業界トレンドや最新事例を網羅。最新の動向を知ることができる場として、好評を得ています。

直近開催のイベントはこちら!

Security Online Day 2022

2022年9月16日(金)10:00~17:10

EnterpriseZine(エンタープライズジン)編集部では、情報システム担当、セキュリティ担当の方々向けの講座「EnterpriseZine Academy」や、すべてのITパーソンに向けた「新エバンジェリスト養成講座」などの講座を企画しています。EnterpriseZine編集部ならではの切り口・企画・講師セレクトで、明日を担うIT人材の育成をミッションに展開しております。

お申し込み受付中!

MySQLチューニング虎の巻

MySQLチューニング虎の巻/ソートに関連するトピックとクエリの書き換え

003


SQLチューニング最後の締めとして、今回はソートに関連するトピックとクエリの書き換えについて触れておこう。これまで、MySQLのJOINに関連した実装および最適化アルゴリズムについて解説してきたが、今回のエントリではそれ以外のアルゴリズムでよく使われるものについて解説する。今回も例によってMySQLの公式サンプルであるworldデータベースを使って解説を行う。worldデータベースについての詳細は次の記事を参照にして頂きたい。>> MySQLにおけるデータベース作成/テーブル作成/サンプルデータ登録

ORDER BY

 アプリケーション開発において、RDBMS側でソートを行う機会は非常に多い。MySQLでは、テーブルから条件にマッチするレコードをインデックス順にキーを読み込むことが出来る場合には、その後さらにソートをする必要はない。(MEMORYストレージエンジンやNDBストレージエンジンで利用可能なハッシュインデックスはそもそもソートには利用できない。)ソートが必要になるのはインデックス順にレコードを読み込むことができない場合である。

 インデックス順にレコードを読み込むことが出来る場合とはどのようなクエリであろうか。JOINが絡むと話がややこしくなるので、まずは単一のテーブルをSELECTする場合について解説したい。

 対象のテーブルがひとつだけの場合、ソートにインデックスを利用できる条件はズバリ次の通りである。

  •  単一のインデックスだけが使われている。
  •   カラム全体がインデックスに含まれている。(プレフィックスだけがインデックスに含まれている場合にはソートに利用できない。)
  •  マルチカラムインデックスの場合、インデックスに含まれるカラム(キーパート)が左から順に利用されている。
  •  マルチカラムインデックスのそれぞれのキーパートのソート順が同じである。

インデックスを使ってソートができるクエリで典型的なものは次のようなものであろう。

mysql> EXPLAIN SELECT * FROM Country WHERE Code LIKE 'j%' ORDER BY Code\G
*************************** 1. row ***************************
           id: 1
  select_type: SIMPLE
        table: country
         type: range
possible_keys: PRIMARY
          key: PRIMARY
      key_len: 3
          ref: NULL
         rows: 3
        Extra: Using where
1 row in set (0.00 sec)

 EXPLAINの見方については本連載の第一回である次の記事を参照して頂きたい。
MySQLにおけるJOINのチューニングの定石

次のページ

この記事は参考になりましたか?

  • Facebook
  • Twitter
  • Pocket
  • note
MySQLチューニング虎の巻連載記事一覧

もっと読む

この記事の著者

奥野 幹也 (オクノ ミキヤ)

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

EnterpriseZine(エンタープライズジン)
https://enterprisezine.jp/article/detail/3695 2012/02/10 18:27

Job Board

PR

おすすめ

アクセスランキング

アクセスランキング

イベント

EnterpriseZine(エンタープライズジン)編集部では、情報システム担当、セキュリティ担当の方々向けに、EnterpriseZine Day、Security Online Day、DataTechという、3つのイベントを開催しております。それぞれ編集部独自の切り口で、業界トレンドや最新事例を網羅。最新の動向を知ることができる場として、好評を得ています。

2022年9月16日(金)10:00~17:10

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング