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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

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

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

Q&A

0回答

380閲覧

cakephp4 複数検索(select式と記述式のAND検索)

aburazemi

総合スコア0

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

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

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

0グッド

0クリップ

投稿2022/11/11 08:01

編集2022/11/28 06:23

前提

開発環境
docker,cakephp4,mysql
を使用しています。

作成したテーブルは
companies,projects,project_users(中間テーブル),documents,users
です。

cakephp4でファイル検索機能を主にしたシステム開発を行っています。
状態としてはDBを作成し、template、model、controllerのbakeを行ったばかりです。
また、検索バーの作成を行いました。

現在の問題点としては、
記述式の検索バーを作ることはできたのですが、選択式の検索が実装できません。

実現したいこと

searchと表の間にセレクトボックスをいれてプロジェクト番号を選択することで選択したプロジェクト番号を持つカラムのみの表示にしたいです。
2つとも値がセットされていたらAND検索にしたいです。

documentテーブル内イメージ説明

該当のソースコード

DocumentsController.php

cakephp4

1class DocumentsController extends AppController 2{ 3 public function index() 4 { 5 $key = $this->request->getQuery('key'); 6 7 if($key){ 8 9 $query = $this->Documents->find('all')->where(['name like' =>'%'.$key.'%']); 10 11 }else{ 12 13 $query = $this->Documents; 14 15 } 16 17 $this->loadModel('Projects'); 18 $projects = $this->Projects->find('all'); 19 $this->set(compact('projects')); 20 21 22 23 $this->paginate = [ 24 'contain' => ['Projects', 'Users'], 25 ]; 26 $documents = $this->paginate($query); 27 28 $this->set(compact('documents')); 29 30 } 31
<div class="documents index content"> <?= $this->Html->link(__('New Document'), ['action' => 'add'], ['class' => 'button float-right']) ?> <h3><?= __('Documents') ?></h3> <?= $this->Form->create(null, ['type' => 'get']) ?> <?= $this->Form->control('key', ['label' => 'Search', 'value' => $this->request->getQuery('key')]) ?> <?= $this->Form->end() ?> <div class="table-responsive"> <table> <thead> <tr> <th><?= $this->Paginator->sort('プロジェクト番号') ?></th> <th><?= $this->Paginator->sort('期') ?></th> <th><?= $this->Paginator->sort('枝番') ?></th> <th><?= $this->Paginator->sort('ファイル区分') ?></th> <th><?= $this->Paginator->sort('担当者') ?></th> <th><?= $this->Paginator->sort('created') ?></th> <th><?= $this->Paginator->sort('modified') ?></th> <th class="actions"><?= __('Actions') ?></th> </tr> </thead> <tbody> <?php foreach ($documents as $document): ?> <tr> <td><?= $document->has('project') ? $this->Html->link($document->project->recordnumber, ['controller' => 'Projects', 'action' => 'view', $document->project->id]) : '' ?></td> <td><?= $document->has('project') ? $this->Html->link($document->project->period, ['controller' => 'Projects', 'action' => 'view', $document->project->id]) : '' ?></td> <td><?= h($document->edaban) ?></td> <td><?= $this->Number->format($document->documentfile) ?></td> <td><?= $document->has('user') ? $this->Html->link($document->user->name, ['controller' => 'Users', 'action' => 'view', $document->user->id]) : '' ?></td> <td><?= h($document->created) ?></td> <td><?= h($document->modified) ?></td> <td class="actions"> <?= $this->Html->link(__('View'), ['action' => 'view', $document->id]) ?> <?= $this->Html->link(__('Edit'), ['action' => 'edit', $document->id]) ?> <?= $this->Form->postLink(__('Delete'), ['action' => 'delete', $document->id], ['confirm' => __('Are you sure you want to delete # {0}?', $document->id)]) ?> </td> </tr> <?php endforeach; ?> </tbody> </table> </div> <div class="paginator"> <ul class="pagination"> <?= $this->Paginator->first('<< ' . __('first')) ?> <?= $this->Paginator->prev('< ' . __('previous')) ?> <?= $this->Paginator->numbers() ?> <?= $this->Paginator->next(__('next') . ' >') ?> <?= $this->Paginator->last(__('last') . ' >>') ?> </ul> <p><?= $this->Paginator->counter(__('Page {{page}} of {{pages}}, showing {{current}} record(s) out of {{count}} total')) ?></p> </div> </div>

試したこと

この方のリンクを参考にしました。
https://teratail.com/questions/78668

補足情報

cakephp4を触り初めてまだ1ヶ月たっていない初心者です。
基礎的な質問かもしれませんがご回答のほどよろしくお願いいたします。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問