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

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

ただいまの
回答率

87.94%

WHERE句のLIKEで*は使えない?

解決済

回答 5

投稿

  • 評価
  • クリップ 1
  • VIEW 4,792

score 403

SELECT * FROM user_data WHERE name3 LIKE '%ヤマダ%';
では読み込めますが

SELECT * FROM user_data WHERE * LIKE '%ヤマダ%';
ではエラーがでます。

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near '* LIKE '%ヤマダ%'' at line 1

syntaxエラーとのことですが、name3を*に変えただけです。

WHERE句で全カラム検索とかはできないのでしょうか?

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 5

+4

なるほど、発想が柔軟でちょっと感心しました。できても良さそうですよね。
私も昔、or で似たようなことを考えたことがあります。

a = 1 or a = 2 が a = 1 or 2 となぜ書けないのかみたいなことですが、
SQLに関しては、in で、できますけどね。→ a in(1,2)
プログラミング言語では出来ませんね。

WHERE * LIKE '%ヤマダ%';  がなぜ出来ないのか考えてみたのですが
やはりカラムによっていろいろな型があるからかなと思います。

LIKE演算子は、charやvarchar等の文字列型の評価をするものなので、
日付型とか整数、小数型では、どのように評価したら良いか決められないからでしょうね。

なので結局 column1 like '%ヤマダ%';  or column2 like '%ヤマダ%'; のようにするしか無いですね。

どのような構文が許可されるのかは、各DBとISOで規定されたSQLがあるので、検索してみると良いかも知れません。

いろいろと覚えてくると当たり前に思って頭が固くなってきますので、そのやわらか頭は大切にして欲しいと思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/06/28 11:50

    ありがとうございます。
    柔軟だといいのですが、ただWHERE句に*は使えないことを知らなかったです汗

    キャンセル

  • 2016/06/28 12:31

    > プログラミング言語では出来ませんね。
    COBOLでは書けますけどね。どの言語にも真似されなかった。

    キャンセル

  • 2016/06/30 09:47

    > otnさん

    そうなんですね、知りませんでした、ありがとうございます。
    無知を晒したようでお恥かしい限り ^_^;
    精進致します。

    キャンセル

checkベストアンサー

+3

できません。
そういった発想は今までなかったので新鮮です。
やり方としては以下のいずれかかと思います。

カラムを1つずつORでつなげる
カラム1 LIKE '%ワード%' OR カラム2 LIKE '%ワード%' …

カラムを結合したものに対してLIKEする
CONCAT(カラム1,カラム2,…) LIKE '%ワード%'

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/06/28 11:51

    ありがとうございます。
    WHERE句で*が使えたら便利だなぁと思いました。

    現行では繋げるしかないのですね...

    キャンセル

+3

>WHERE句で全カラム検索とかはできないのでしょうか?
できません。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/06/28 11:48

    ありがとうございます。

    キャンセル

+3

WHERE句に*はできません。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/06/28 11:48

    ありがとうございます。

    キャンセル

+2

私もttyp03さんとほぼ回答ですが、少しアレンジ。

CONCAT(カラム1,カラム2,…) LIKE '%ワード%'
のパターンだとカラム1の末尾に「ワー」カラム2の先頭に「ド」があった場合もヒットします。

これも含めて検索したい場合はよいのですが、それを防ぎたい場合は、
CONCAT(カラム1,'||',カラム2,'||',…) LIKE '%ワード%'
のように区切り文字を入れます。
区切り文字はなんでもよく、検索キーワードに使わないであろう文字列を使います。

ウチではMySQL独自関数であるCONCAT_WSを使ってこんな感じに書くことがあります。
CONCAT_WS('||',カラム1,カラム2,…) LIKE '%ワード%'

[参考] MariaDBドキュメント > CONCAT_WS

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/06/28 11:52

    ありがとうございます。
    参考にさせて頂きます。

    キャンセル

  • 2016/06/28 14:45

    カラム間の区切りはあったほうが良いですね。
    CONCAT_WSは知らなかったので参考になります。

    キャンセル

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

  • ただいまの回答率 87.94%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る