
mysqlのインデックスについて質問です。
http://archiva.jp/web/server-side/sql_02.html に、
『mysqlでは1つのクエリ実行で、1つのテーブルにつき1つのインデックスしか使用できない』
とあります。
よく以下のようなテーブル定義を見かけますが、
CREATE TABLE IF NOT EXISTS `data` (
`id` int(10) NOT NULL default '0',
`user_id` int(10) NOT NULL default '0',
`file_id` int(10) NOT NULL default '0',
`name` text collate utf8_unicode_ci NOT NULL default '',
PRIMARY KEY (`id`),
KEY `user_id` (`user_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
idとuser_idを条件にするクエリであれば、上記制約を満たすため、
KEY `id_user_id_idx` (`id`,`user_id`)
の複合クエリを定義すれば良いのでしょうか?
また、idとuser_idとfile_idを条件にするクエリも考慮に入れた場合、
テーブル定義は以下のようにするのでしょうか?
CREATE TABLE IF NOT EXISTS `data` (
`id` int(10) NOT NULL default '0',
`user_id` int(10) NOT NULL default '0',
`file_id` int(10) NOT NULL default '0',
`name` text collate utf8_unicode_ci NOT NULL default '',
PRIMARY KEY (`id`),
KEY `user_id` (`user_id`),
KEY `id_user_id_idx` (`id`,`user_id`),
KEY `id_user_id_file_id_idx` (`id`,`user_id`,`file_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
最後に、create table 時のインデックスの指定は、
INDEX `user_id` (`user_id`),
のようにもできますが、INDEXとKEYの違いは何かあるのでしょうか。
No.1ベストアンサー
- 回答日時:
古いMySQLなら"1つのクエリで1テーブルにつき1インデックスしか使われない"というのは正しいです。
しかし、新しいMySQL(ver.5.0以降)ならインデックスマージが行われるので、もし複数のIndexが使えるとオプティマイザが判断をした場合には、複数のインデックスが使われます。ただ、例で挙がられた"idとuser_idを条件にするクエリ"の場合、PRIMARY KEYであるidカラムで1行のみに絞り込めます。わざわざ複数のIndexを使わずに、PRIMARY KEYを使って対象の1行を取り出してから"指定されたuser_idと一致するかどうか判断する"という最適化をオプティマイザが判断してしまうとuser_idのインデックスは利用されません。
また、検索条件に完全に一致したインデックスが無くても、対象行の絞込みが行える場合には、オプティマイザはインデックスを利用して対象行の絞込みを行ないます。インデックスで絞り込んだ中から条件に一致した結果を返すので、インデックスだけで絞り込んだ場合より多少遅くなりますが、まったくインデックスが無かった場合より早く結果を返せます。
また、複合カラムインデックスは、初めのカラムだけが条件に指定された場合でも有効に活用されますので、検索条件次第ですが、同じカラムの並びでインデックスを複数作成する必要はありません。
http://dev.mysql.com/doc/refman/5.1/ja/mysql-ind …
インデックスを大量に作成すると更新時の処理が重くなるので、更新と参照のバランスを考えて必要なインデックスを作成してください。
"INDEXとKEYの違いは?"については、同じINDEX作成用の定義文なので、好みにあわせて好きなほうを使ってもらってかまいません。
参考URL:http://dev.mysql.com/doc/refman/5.1/ja/index-mer …
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL my_itemsテーブルのIDにAUTO_INCREMENT を追加ができるかで 1 2023/01/03 09:09
- MySQL エラー 1068 (42000): 複数の主キーが定義されていますエラー 2 2022/11/17 04:36
- MySQL `picture` varchar(255) のコマンドで間違いないでしょうか? 1 2022/11/21 04:08
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
- MySQL SHOW CREATE TABLE posts;これって何ですか? 3 2022/08/28 22:57
- MySQL MYSQL エラー 2 2022/10/18 11:37
- MySQL あと、MySQLの文字コードはutf8 気になりますね 1 2022/12/01 07:22
- PHP php テーブルが作成できない 1 2022/11/17 23:41
- MySQL php テーブルを作れない 2 2022/11/17 18:22
- MySQL PHPとMySQLを使った掲示板の作り方 1 2022/06/02 13:00
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
テーブル作成について質問があ...
-
SQLiteでご教示願います。
-
参照先に値が無い場合空欄にす...
-
この場合の賢いSQL文は?
-
PHP+MySQLで文が正しいのに実行...
-
PHP/MySQL INSERT文について。
-
mySQLのカラムの並び順によるデ...
-
SELECT クエリーの OR の使い方...
-
DDLのインポート方法
-
UPDATE文のエラー直せますでし...
-
特定の範囲のデータを削除するには
-
テーブルが5つの時の結合の仕...
-
エクセルで最後の文字だけ置き...
-
mysqlのインデックスについて質...
-
2つのテーブルを連結させる方法
-
2つの関連するテーブルの並び替え
-
レコードAとBが等しい場合にupd...
-
SQL文を教えてください
-
複数のテーブルからのデータ抽出
-
カラムを好きな順で並び替え(...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
エクセルの関数について教えて...
-
select文のwhere句に配列を入れ...
-
VIEWの元のテーブルのindexって...
-
エラー 1068 (42000): 複数の主...
-
SQLにて特定の文字を除いた検索...
-
【Transact-sql】 execの結果を...
-
マイクラPC版のコマンドで効率...
-
SQL Left Join で重複を排除す...
-
sqlで、600行あるテーブルを100...
-
複数テーブルのGROUP BY の使い...
-
WordpressのContact form 7でzi...
-
クエリ表示と、ADOで抽出したレ...
-
SQLサーバから、項目の属性(型...
-
selectした大量データをinsert...
-
Access パラメータクエリをcsv...
-
副問合せの書き方について
-
inner joinをすると数がおかし...
-
insertを高速化させたい
-
[MySQL] 3つのテーブルの結合で...
おすすめ情報