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

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

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

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

CakePHP

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

Q&A

解決済

1回答

2630閲覧

Cakephp3での複数テーブル間でのデータ取得とソートの条件設定について

nagasa

総合スコア35

MySQL

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

CakePHP

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

0グッド

0クリップ

投稿2017/04/16 09:22

現在、Cakephp3でブログサイトを構築しています。その際にユーザーが自分のフォローしているユーザーの情報(名前等)と
そのユーザーの最新の投稿の情報のみを取得して、表示したいと考えています。その為、下記のような形で
findでデータを取得しようと考えています。

環境:
php:7.1.1
Apache/2.4.25 (Win32)
cakephp:3.2.11
MySQL:10.1.21-MariaDB

テーブル:
Followers:フォローしているユーザーのID等を管理
FollowedUsers :フォローされているユーザーのテーブル名
(本来のテーブル名はUsersですが、containする際にはフォローするユーザーとフォローされるユーザーとで両方がUsersを参照してしまうのでFollowersでcontainする際のみ名前を区別させています。)
Articles :記事情報

$query = $this->Followers->find() ->where(['followid'=>$this->Auth->user('id')]) ->contain(['FollowedUsers','FollowedUsers.Articles']) (ここから先の条件設定ができない) 下記の条件を加えてみましたが、エラーとなる ->order(["FollowedUsers.Articles.created" => 'DESC' ]);(最新の記事を一番目に持ってくる。) $this->set('followers',$this->paginate($query));

フォローしているユーザーの情報とそのユーザーの最新記事のみを取得して、表示させたいのですが、
良い方法をご教授頂きたくよろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

stackoverflowに類似の質問があり、詳しい解説が載っていましたので参考にしてください。

How to limit contained associations per record/group?

※ユーザとhasOneの関係で、そのユーザの最新記事(LatestArticles)というアソシエーションを定義してあげれば、できるのではないかと(ただ、FollowedUsers.LatestArticlesとネストが深いのでうまくいかなかったらすみません...)

投稿2017/04/16 22:31

編集2017/04/16 22:39
popobot

総合スコア6586

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

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

nagasa

2017/04/17 00:14

ありがとうございます。結構むずかしくなりそうなのですね。確認します。
popobot

2017/04/17 01:05

そうですね、少しややこしいですね。 データベース上に、各ユーザの最新記事というViewを作る手もありますね。 結果同じSQLになるので、CakePHPでやるかDBでやるかの違いですが
nagasa

2017/04/17 06:04

なかなか、SQLとか複雑になりそうなので、今のところは新たに最新記事のDBを作成することにします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問