Posted on

CakePHPのqueryのキャッシュでハマる

モデルのquery関数を使ってループをまわしながら最大noをとってくる処理でハマりました・・・
query関数って$sql同じだった場合勝手にキャッシュを使って前回と同じ値を返すんですね。
通常はこれを回避する為に

  1. $this->query($sql, false);  

とすることで毎回最新データを取ってきてくれます。
デフォルトでキャッシュが邪魔だったので、app_model.phpで

  1. function query() {  
  2. $params = func_get_args();  
  3. if (emptyempty($params[1])) {  
  4. $params[1] = false;  
  5. else {  
  6. if (is_array($params[1]) && emptyempty($params[2])) {  
  7. $params[2] = false;  
  8. }  
  9. }  
  10. $db =& ConnectionManager::getDataSource($this->useDbConfig);  
  11. return call_user_func_array(array(&$db'query'), $params);  
  12. }  

query関数をオーバーライドしました。
バージョンは1.2.6です。