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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

正規表現

正規表現とは特定の文字列によるパターンマッチングを行う際に用いられる宣言型プログラミングです。

Q&A

1回答

2975閲覧

約2000万レコードのDB(mysql)から、正規表現(REGEXP)で検索する際の高速化対応について

totomomo_akakak

総合スコア13

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

正規表現

正規表現とは特定の文字列によるパターンマッチングを行う際に用いられる宣言型プログラミングです。

0グッド

2クリップ

投稿2017/06/02 10:32

宜しくお願いいたします。

MysqlのREGEXP(正規表現)を用いて、2000万行の住所マスターから、特定のキーワードを含むレコードを検索する際、REGEXPの仕様でindexが効かず、結果取得にものすごい時間を要してしまいます。

likeを用いらない理由ですが、複数のキーワードで検索を行うために、REGEXPを用いております。

処理の時間を短縮する方法はありますでしょうか?
お知恵を拝借できますと幸いです。

サンプルとして、テーブル構造と、実行しているsqlを添付します。

■テーブル構造
ken_name city_name town_name aza_name address
北海道 札幌市中央区 北1条東 11丁目 22−41

■SQL
SELECT DISTINCT CONCAT(IFNULL(ken_name,''),IFNULL(city_name,''),IFNULL(town_name,''),IFNULL(aza_name,''),IFNULL(address,'')), ken_name, city_name, town_name, aza_name , address
FROM phonebook_houzin
WHERE CONCAT(IFNULL(ken_name,''),IFNULL(city_name,''),IFNULL(town_name,''),IFNULL(aza_name,''),IFNULL(address,'')) REGEXP '.*北海.*中央.*北.*条.*東.*1?.4?.';

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

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

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

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

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

coba-coba

2017/06/02 18:58

「全文検索」がおすすめなのですが、そのために仕様変更やMySQLのバージョンを対応させることはできるのでしょうか?
guest

回答1

0

まさに正規表現はインデックスをつかわないので諦めて下さい
住所の場合ある程度まで正規化できるので絞り込めば
作業量は数十分の一にはなるんじゃないですか?

投稿2017/06/02 10:55

yambejp

総合スコア114769

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問