CakePHPのPaginateでjoinしたモデルのカラムでソートする方法

CakePHPのPaginate便利ですよね。特に設定しなくても、ソートもページングもできる。素晴らしい。ただ、joinしているモデルのカラムをキーにソートしようとすると効かないという…。どうしよう。

答え→バーチャルフィールドを設定する

解決方法は簡単で、ソートしたいカラムをバーチャルフィールドとして登録するだけです。

model.php


class Hoge extends AppModel {
	var $virtualFields = array(
		‘hoge’ => ‘JoinTable.hoge’
	);

view.ctp

 echo $this->Hoge->sort(‘hoge’,’ソートキー’); ?>

ただし、ソートのためだけにバーチャルフィールドを設定するとfindした時にうざったいことになる可能性があるので、必要な時だけに設定するのが吉。

ちなみに、なぜjoinしているモデルではソートできないのかというと、URLに適当なキーを直接入力してエラーになるのを防ぐためらしい。

Feed

最新記事

開発フローを独自進化させ続けている開発チームの話

こんにちは CTO の [@zaru](https://twitter.com/zaru) です。 スクラム開発をしている開発チームが、開発フローを独自進化させていて、それが良い取り組みだったので紹介しようと思います。 #...

235650?v=4
zaru
2017年11月20日

退職者を招いたLTイベントを開催した

こんにちは、ベーシック CTO [@zaru](https://twitter.com/zaru) です。 ベーシック開発部では毎月月末の金曜日にTGIFと称して、 ~~飲み会 + アナログゲームなイベント~~ 技術 LT 大会...

235650?v=4
zaru
2017年10月12日

山形ラボ、TGIFはじめました

こんにちは。株式会社ベーシック山形ラボの長谷川です。 いろんなところで書いたりなんだりしてますが、弊社には山形に「山形ラボ」というリモート拠点がありまして、そこで4人のエンジニアが働いております。 今回は その山形ラボで、...

10917612?v=4
roki1801
2017年10月10日