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

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

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

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

Q&A

1回答

2688閲覧

cakephp のfindで検索フォーム

chNOBUNAGA

総合スコア41

CakePHP

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

0グッド

1クリップ

投稿2017/06/04 04:35

下記の条件で、検索をしたいのですがスマートなやりかたが思いつきません。
・名前
・性別
・年齢
・学歴

これれは
セレクトボックスで検索ボタンを一つ押してgetで値を取得しているのですが、

findを使ってどのようにすればコードをを少なくできるのでしょうか?
if分を使って各項目順にコーティングするのもいいと思いますが
スマートじゃありません。

何かいい方法はありますか?

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2017/06/04 05:14

テーブルの定義が示されていないので、回答のしようがありません。CREATE TABLE で表現される定義を提示してください。
chNOBUNAGA

2017/06/04 05:16

からむ:age(名前),sex(性別),name(ナマエ),rank(学歴) テーブル:school
chNOBUNAGA

2017/06/04 05:16

宜しくお願いします。
退会済みユーザー

退会済みユーザー

2017/06/04 05:16

CREATE TABLE で表現される定義を提示してください。
guest

回答1

0

実際のコードなどがないため回答が難しいですが、このようにしてはいかがでしょうか?

PHP

1// GETリクエストの取得 2$requestData = $this->request->query(); 3 4// 検索条件の作成 5$conditions = [ 6 'name', 7 'sexCode', 8 'age', 9 'schoolCareer' 10]; 11$conditions = array_merge($conditions, $requestData); 12 13// 値が空の場合、検索条件から除外 14foreach ($conditions as $key => $val) { 15 if (empty($val)) { 16 unset($conditions[$key]); 17 } 18} 19 20// 検索処理 21$data = $this->TableClassName->find() 22 ->where($conditions) 23 ->all() 24 ->toArray();

このようにすれば、検索条件やバリデーション用のデータを作成するときにも同様に処理をすることができるかと思います。
参考になれば幸いです^^

投稿2017/06/04 05:19

TakuyaHidaka

総合スコア137

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

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

chNOBUNAGA

2017/06/04 05:23

ありがとうございます。 ちなみにこれを年齢<Xや年齢>Xにするには、どのようにすればいいでしょうか?
TakuyaHidaka

2017/06/04 05:31 編集

年齢に対する条件値の処理が変化しないのであれば、 ---- // 検索条件の作成 $conditions = [ 'name', 'sexCode', 'age <', 'age >', 'schoolCareer' ]; --- とすれば、よいと思います。 おそらくフォームの年齢は、何歳以上何歳以下と入力できるようになっているものと思います。 フォームのname属性がそれぞれage_from, age_toなどとなっていれば同様に条件追加すれば大丈夫だと思います。
chNOBUNAGA

2017/06/04 05:41

セクレクトボックスですが、 10,〜30ように変化しますが、こちらは要素を値にして追加すればよろしいのでしょうか?
TakuyaHidaka

2017/06/04 05:51

値に応じて、$conditionsのキーを追加することになります。 今回のように [年齢] がそのような値の構成ですと、どうしてもIf文に頼ることになると思います。 値の意味合いが変わらないものについては、上記のような方法で大丈夫でしょう^^
TakuyaHidaka

2017/06/04 05:52

画面のキャプチャがあるともう少し正確に回答できるのですが、大丈夫ですか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問