電子書籍の厳選無料作品が豊富!

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    |
+-------+    +-------+

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

A 回答 (1件)

SELECT * FROM `a1` , `b1` WHERE a1.a2 LIKE CONCAT('%',b1.b2,'%');


ってことでしょうけどSQLとしてはいただけないですね

SELECT * FROM `a1` , `b1` WHERE a1.a2 REGEXP b1.b2;
っていうのもあります
    • good
    • 0
この回答へのお礼

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

お礼日時:2007/11/12 10:56

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

関連するカテゴリからQ&Aを探す