group byのSQLでインデックスは使えないものなのでしょうか.
Using filesortにより,全レコードを読んでしまっています.
どなたか解決法を教えてください.
mysql> describe xxxxx;
+--------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+--------+--------------+------+-----+---------+----------------+
| aaa_id | bigint(20) | | PRI | NULL | auto_increment |
| bbb_id | bigint(20) | | MUL | 0 | |
| ccc_id | bigint(20) | | MUL | 0 | |
+--------+--------------+------+-----+---------+----------------+
mysql> explain select ccc_id from xxxxx group by ccc_id =2;
+----+-------------+-------+-------+---------------+--------+---------+------+------+----------------------------------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-------+-------+---------------+--------+---------+------+------+----------------------------------------------+
| 1 | SIMPLE | xxxxx | index | NULL | ccc_id | 8 | NULL | 628 | Using index; Using temporary; Using filesort |
+----+-------------+-------+-------+---------------+--------+---------+------+------+----------------------------------------------+
No.3ベストアンサー
- 回答日時:
#2回答者です。
「group by 列名1=2」については、MySQLの拡張仕様というのは私の勘違いでした。ただ、この指定では「『列名1=2』のものと『列名1<>2』のものをそれぞれグループ化(二つのグループを作る)」という意味ですが、やりたいことはそれであっているのでしょうか?
数パターンでEXPLAINを行ってみましたが、単純な列でなく列の演算を行うと、インデクスが使用されないようです。
この回答への補足
「『列名1=2』のものと『列名1<>2』のものをそれぞれグループ化(二つのグループを作る)」という意味ですが、やりたいことはそれであっているのでしょうか?
ただ,上の意味でもやっている箇所があり,
この回答は大変参考になりました.
ありがとうございます
No.4
- 回答日時:
>select max(ddd_id) from xxxxx group by ccc_id =2;
いまいちイメージがわきませんが、
ccc_idが2のときのddd_idの最大値だったら
group by するまでもないのでは?
select max(ddd_id) from xxxxx where ccc_id =2;
この回答への補足
そして,
端折っていた部分に原因があったようです.
私の記述があいまいだったために
皆様を悩ませてしまいました.
申し訳ありません.
実は
[where bbb_id = 2]
が,隠れており,
bbb_id =2に該当するレコードが多かったため
インデックスではなく,ソートになっていたようです.
大変お手数おかけいたして申し訳ありません
皆様ありがとうございました
No.2
- 回答日時:
長年、いろいろなRDBMSを見てきましたが、「group by ccc_id =2」という構文を見たのは初めてです。
MySQLではエラーにならず、拡張仕様のようですが、どういう意味なのでしょうか?質問者さんの意図したものと合致しているでしょうか?一般的なSQLでは、「where 列名1=2 group by 列名1」や「group by 列名1 having 列名1=2」といった書き方はありますけどね。
なお、「select max(列名1) from 表名 where 列名2=2 group by 列名2」や「select max(列名1) from 表名 group by 列名2 having 列名2」といった一般的な書き方なら、「create index インデクス名 on 表名(列名2,列名1)」というインデクスを定義すれば、少なくともバージョン5.0.19では当該インデクスが使用されます。
「group by 列名2=2」といった書き方はエラーにはなりませんが、インデクスは使用されません。
この回答への補足
「group by 列名1 having 列名1=2」
の書き方を端折り過ぎていました.
わかりにくくして申し訳ありませんでした.
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL my_itemsテーブルのIDにAUTO_INCREMENT を追加ができるかで 1 2023/01/03 09:09
- MySQL `picture` varchar(255) のコマンドで間違いないでしょうか? 1 2022/11/21 04:08
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
- MySQL エラー 1068 (42000): 複数の主キーが定義されていますエラー 2 2022/11/17 04:36
- AJAX JavascriptからPHPへのAjax通信でnullが返ってくる 3 2022/08/03 22:00
- Access(アクセス) アクセス 有効なフィールド名、または式として認識できませんのエラー 3 2022/08/19 11:53
- MySQL php テーブルを作れない 2 2022/11/17 18:22
- PHP php テーブルが作成できない 1 2022/11/17 23:41
- JavaScript プログラムがうまく動きませんレビューお願いします 1 2022/07/10 05:08
- SQL Server ACCESSで表が作りたく、そのためのSQL文や設定方法を教えてください。 1 2022/08/15 12:28
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
VIEWの元のテーブルのindexって...
-
入力値と外部キーをINSERTするには
-
SQLサーバから、項目の属性(型...
-
select文のwhere句に配列を入れ...
-
inner joinをすると数がおかし...
-
MySQLのDATE型カラム値がNULLの...
-
ある条件の最大値+1を初番する...
-
クエリ表示と、ADOで抽出したレ...
-
同一のユーザー、同一商品のと...
-
複数のUPDATE文の実行
-
全角文字を含む行を検索
-
Updateの複数テーブル条件時のL...
-
エクセルの関数について教えて...
-
テーブル作成です。どこかのス...
-
php+mysqlで複数選択削除について
-
MySQLのint型で001と表示する方...
-
別のDB(Table)からの複数行の...
-
書籍の内容はまともでしょうか?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
副問合せの書き方について
-
SQLサーバから、項目の属性(型...
-
SQL Left Join で重複を排除す...
-
select文のwhere句に配列を入れ...
-
VIEWの元のテーブルのindexって...
-
PL/SQLの変数について
-
マイクラPC版のコマンドで効率...
-
エクセルの関数について教えて...
-
SQLにて特定の文字を除いた検索...
-
sqlで、600行あるテーブルを100...
-
Access パラメータクエリをcsv...
-
Unionした最後にGROUP BYを追加...
-
inner joinをすると数がおかし...
-
複数テーブルのGROUP BY の使い...
-
ある条件の最大値+1を初番する...
-
MySQLのint型で001と表示する方...
-
クエリ表示と、ADOで抽出したレ...
-
[MySQL] UNIQUE制約の値を更新...
-
テーブル名を省略して「h.id」...
おすすめ情報