前提・実現したいこと
SQL入門者で、インデックスの貼り方を知りたいです
発生している問題
インデックスが貼れているのに、効かないという状態かと思います
該当のソースコード
こちらがテーブルで、urlカラムにインデックスを貼っています
SQL
1create table test_index ( 2 id int(10) not null auto_increment, 3 school varchar(4) not null, 4 url varchar(100) not null, 5 index idx_url(url), 6 primary key(id)); 7 8insert into test_index (id, school, url) 9values 10#以下は2件ですが、後述するJSで100件作りここに入れます 11(1, '梅高', '27qM'), (2, '竹高', 'ujCx') 12;
次のJSのresultを上のvaluesに入れてデータを作りました(これは問題ありません)
js
1var result = ""; 2for ( var i = 1; i < 100; i++ ) { 3 var rand = getRand(); 4 var school = getSchool(); 5 result += "("+i+", '"+school+"', '"+rand+"'), "; 6} 7console.log('result='+result.slice( 0, -2 )); 8 9function getRand(){ 10 var S = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789" 11 var N = 4; 12 return Array.from(Array(N)).map(()=>S[Math.floor(Math.random()*S.length)]).join(''); 13} 14 15function getSchool(){ 16 var array = ["松校", "竹高", "梅高"]; 17 return array[Math.floor(Math.random() * array.length)]; 18}
試したこと
貼られているか確認しました
sql
1show index in test_index;
↓貼られているようです
sql
1test_index 0 PRIMARY 1 id A 99 NULL NULL BTREE 2test_index 1 idx_url 1 url A NULL NULL NULL BTREE
続いて効いているか確認しました
sql
1explain 2SELECT * 3FROM test_index t 4WHERE url like "%a%";
↓効いていないみたいなんです(5つ目の値がALLだと効いていないという理解です)
sql
11 SIMPLE t NULL ALL NULL NULL NULL NULL 99 11.11 Using where
かくして「インデックスが貼れているのに、効かないという状態かと思います。」という問題だと認識し、質問させて頂きました
どうやって効かせることができますでしょうか、、
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/05/04 12:52
2020/05/04 12:56
2020/05/04 13:26