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

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

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

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

3回答

5221閲覧

CakePHP3のOR検索について

ssk

総合スコア332

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

0クリップ

投稿2017/01/26 05:47

PHP

1//HogesController.php 2$query = $this->Articles->find() 3 ->where(function ($exp, $q) use ($arrayWord) { 4 if (is_array($arrayWord) && count($arrayWord) > 0) { 5 foreach ($arrayWord as $key => $value) { 6 $exp->like('title', '%'.$value.'%'); 7 } 8 } 9 return $exp; 10 })

SQL

1//生成されるSQL文 2body LIKE '%あ%' 3AND body LIKE '%い%' 4AND body LIKE '%う%'

一言多いプログラマーの独り言より抜粋

#####知りたいこと

SQL

1//生成されるSQL文 2body LIKE '%あ%' 3AND body LIKE '%い%' 4AND body LIKE '%う%'

↓変更

SQL

1//生成されるSQL文 2body LIKE '%あ%' 3OR body LIKE '%い%' 4OR body LIKE '%う%'

ANDをORに変更したいです。

'OR' =>で繋げば大丈夫かと思ったんですがエラー

PHP

1syntax error, unexpected '=>' (T_DOUBLE_ARROW)

となり、できませんでした。

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

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

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

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

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

guest

回答3

0

where()メソッドにOR => [ORするクエリリスト]のような形で行うことができます(CakPHP3のドキュメント)。

php

1$conds = []; 2foreach($arrayWord as $value) { 3 $conds[] = ['body LIKE' => '%'.$value.'%']; 4} 5$query = $this->Articles->find() 6 ->where(['OR' => $conds]);

投稿2017/01/26 06:29

maisumakun

総合スコア145183

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

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

ssk

2017/01/26 06:47

ありがとうございます。 理解することができました。 CakPHP3のドキュメントをスラスラ読めるように努力します。 また、質問するかと思いますが、その際は何卒よろしくお願いいたします。
guest

0

ベストアンサー

以下のような感じですかね。orWhereで条件を追加するとORになります。

php

1$arrayWord = array('あ','い','う') ; 2$query = $this->Articles->find(); 3if (is_array($arrayWord) && count($arrayWord) > 0) { 4 foreach ($arrayWord as $value) { 5 $query->orWhere(function ($exp, $q) use ($value) { 6 $exp->like('title', '%'.$value.'%'); 7 return $exp; 8 }); 9 } 10}

投稿2017/01/26 06:28

編集2017/01/26 06:48
popobot

総合スコア6586

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

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

ssk

2017/01/26 06:45

ありがとうございます。 実行することができました! CakPHP3のドキュメントを参考に、理解できるようにします。
guest

0

or_likeを使用するといいのでは。

投稿2017/01/26 06:09

yona

総合スコア18155

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

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

yona

2017/01/26 06:11

Codeigniterと勘違いしました、この回答は無視してくださいorz
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問