こんにちはゲストさん。会員登録(無料)して質問・回答してみよう!

解決済みの質問

LIKEを用いたあいまい検索の方法

SELECT `a2` FROM `a1` , `b1` WHERE a1.a2 LIKE b1.b2;
を部分一致で検索したいのですが不可能なのでしょうか?
SELECT `a2` FROM `a1` , `b1` WHERE a1.a2 LIKE '%b1.b2%';
とするとエラーは出ないのですが、検索結果が0になってしまうのです。

[開発環境]
MySQL 4.0.x

a1 b1
+--------+    +------+
| a2    |    | b2   |
+-------+    +-------+
| abcde  |    | cd    |
+-------+    +-------+

よろしくお願い致します。

投稿日時 - 2007-11-09 17:44:52

QNo.3503412

すぐに回答ほしいです

質問者が選んだベストアンサー

SELECT * FROM `a1` , `b1` WHERE a1.a2 LIKE CONCAT('%',b1.b2,'%');
ってことでしょうけどSQLとしてはいただけないですね

SELECT * FROM `a1` , `b1` WHERE a1.a2 REGEXP b1.b2;
っていうのもあります

投稿日時 - 2007-11-09 19:19:21

お礼

なるほど!どちらの方法でもうまく検索することができました!見た目の問題から正規表現のほうを採用させていただきました。
本当にありがとうございました。

投稿日時 - 2007-11-12 10:56:22

ANo.1

このQ&Aは役に立ちましたか?

0人が「このQ&Aが役に立った」と投票しています

回答(1)

あなたにオススメの質問