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

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

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

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

Q&A

解決済

2回答

1882閲覧

一つのモデルから同一モデルの異なるレコードを取り出したい。

yu-

総合スコア12

CakePHP

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

0グッド

0クリップ

投稿2016/01/18 22:21

cakePhP3でタスクを管理する機能を作っています。

タスクを管理するテーブルには依頼主と依頼相手を登録するカラムがあり、それぞれUsersテーブルに登録されているユーザーを登録します。

登録する際は、Usersテーブルから取得した値を元にしたSelectBoxから登録しています。
$usr = TableRegistry::get('Users');
$this->set('options', $usr->find('list', array('fields' => array('id','name'))));

登録した後一覧を表示する際、idが表示されますがidではなく名前を表示したいのです。

アソシエーション設定を行い依頼主を表示させることはできたのですが、両方を表示させる方法はありますでしょうか。

初めて質問させていただきますので、質問内容に不備があるかもしれませんが、よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

アソシエーションが適切に設定されていることが前提ですが(この場合Tasks belongs to Users)、TasksControllerでは次のコードでusersテーブルのデータを取得できます。

PHP

1// TasksController 2$data = $this->Tasks->Users->find('all');

TasksテーブルとUsersテーブルのデータをまとめて欲しい場合は、次のようになります。

PHP

1// TasksController 2$data = $this->Tasks->find('all', ['contain' => ['Users']])->toArray();

上記2つの取得方法でUsersテーブルのnameまで取得できます。
また、toArray()をして中身を確認しやすくしています。debut($data);等してご確認ください。


なお、テーブルの構成は、例えば次のようなものを想定しています。
[usersテーブル]
id
name(ユーザー名)

[tasksテーブル]
id
user_id(依頼主・Usersテーブルのid)
request_for(依頼相手・Usersテーブルのid)
task(タスクの内容)

アソシエーションは、
Users has many Tasks
Tasks belongs to Users

テーブルをご覧頂くと分かりますが、依頼相手はアソシエーションしていません。依頼相手の一覧を表示するには、$this->Tasks->Users->find('all')で別途用意する必要があります。
この点で私もいつも悩んでいます。もっと上手なテーブル構成があるかもしれません。

投稿2016/01/19 02:35

編集2016/01/19 02:41
coba-coba

総合スコア1409

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

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

yu-

2016/01/19 03:05

度々ご回答ありがとうございます。 おっしゃる通り、依頼相手に対してアソシエーションを設定していない事から悩んでおりました。 結局、名前を取得するヘルパーを作成し対処する事にしました。 ありがとうございました。
guest

0

セレクトボックスに依頼主のidと名前の両方を表示したいということでしょうか。

その場合は、findするときにmapを使うといいと思います。
次のように取得すると、usersテーブルのidをキー、idとnameをスペースで結合した文字列を値とした、連想配列を取得できます。

PHP

1$usr->find() 2 ->select(['id', 'name']) 3 ->map(function ($row) { 4 $row->id_name = $row->id.' '.$row->name; 5 return $row; 6 }) 7 ->combine('id', 'id_name') 8 ->toArray();

投稿2016/01/19 00:39

coba-coba

総合スコア1409

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

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

yu-

2016/01/19 00:53

ご回答ありがとうございました。表現がわかりにくく申し訳ありません。 Tasksの一覧(index.ctp)を表示する際に表示される登録者名が、セレクトボックスで登録した際のid(Usersテーブルから値を取得し設定したセレクトボックスのvalue値)が表示されます。 Tasksテーブルに登録されている値はidでいいのですが、Tasksのindexで一覧を表示する際のみ、id(キー)をnameに変換したいのが今回の質問内容となります。
coba-coba

2016/01/19 02:42 編集

そういうことだったんですね。 もう一つ回答欄を使ってコメントしましたので、そちらをご覧頂けますか。 もし回答の方向性がずれていたらすみません。 その際にはまたおっしゃって頂けたらと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問