質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

1回答

1593閲覧

SQLでインデックスが貼れなくて困っています

moriazarashi

総合スコア2

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2020/05/04 12:27

前提・実現したいこと

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

かくして「インデックスが貼れているのに、効かないという状態かと思います。」という問題だと認識し、質問させて頂きました

どうやって効かせることができますでしょうか、、

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

どうやって効かせることができますでしょうか、、

無理です。%a%のような部分一致に、今付与したインデックスは効きません。

インデックスの種類としてBTREEと書かれていますが、これは先頭からたどる場合にしか使えません。

(全文検索インデックスというものもありますが、設定方法や詳細はDBエンジンやバージョンによって大きく異なってきます)

投稿2020/05/04 12:32

maisumakun

総合スコア146018

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

moriazarashi

2020/05/04 12:52

はががががっ!!ショックです! どうもありがとうございます。 ところで以下よろしいでしょうか >今付与したインデックスは効きません。 >これは先頭からたどる場合にしか使えません。 ということは「今付与したものではなく、かつ先頭からたどるものである場合」は効かせることができるのでしょうか 言葉の意味がよくわからないのですが、具体的にはどんな方法になるか教えて頂いてもよろしいでしょうか
maisumakun

2020/05/04 12:56

「a%」のような先頭一致であれば、BTREEインデックスも適用されます。
moriazarashi

2020/05/04 13:26

なるほど理解できました!どうもありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問