CakePHPのモデルのキャッシュではまった -新しく追加したカラムに値が入らない-

公開日: : CakePHP, IT


タイトルのとおり、ちょこっとCakePHPではまったのでメモ。

作業内容

  • MySQLで、あるテーブルにカラムを追加。
  • ソースを修正し新しいカラムに値が入るように記述。
  • テスト環境(ローカル環境(Windows)/debug:2)で動作することを確認。
  • ソースをコミット。
  • プレ本番環境、本番環境を最新の状態に更新。

ここまでの流れは普通にあることだと思う。

発生事象

以下の事象が発生。

  • プレ本番環境(CentOS/debug:0)、本番環境(CentOS/debug:0)と新しく追加したカラムにだけ値が入らない。

MySQLでエラーが出ているわけでもなく、正常に処理が出来ているものの値が入らない。
しかしテスト環境だけは問題なく値が入っている。

調査

疑った流れは以下。

1. カラムに入れるべき値がそもそも空なのでは?
明示的に指定してみたけど、値は入らず。

2. カラム名に問題がある?(そんなことはないはず)
どんなカラム名でも新規に追加したものは受け付けないみたい。

3. これはキャッシュか・・?
正解

対処方法

どうやら、app/tmp/cache/modelsの配下にテーブル構造を格納したモデルのキャッシュがあり、これが古いままだったので問題だった。
このキャッシュファイルを削除すれば、問題は解決。

じゃあ、なぜテスト環境だけ動作したのか?
このキャッシュファイルは永続的に残っているかというとそうではなくて、以下のようになっている。

  • debugが0の時は999日
  • debugが0以外の時は15秒

もし、カラムを追加した場合は以下の処理が必要になる。
Cache::delete(‘useDbConfig名_テーブル名’,’_cake_model_’);

広告

関連記事

no image

ターミナルでgitのコマンドを補完したりブランチ名を表示する – macでgitを便利に使うために –

* やりたいこと macのターミナルでgitをいじっていると -今のブランチってなんだっけ? -g

記事を読む

no image

CakePHP1.3にSmartyを導入

いい加減、CakePHP(1.3)にもSmartyを導入することにしました。 * ダウンロード

記事を読む

ndk

Androidアプリ開発 -画像処理をC言語で高速化-

* 画像を扱う際の問題(1):計算処理の遅さ 前回、セピア画像にする方法を書きました。

記事を読む

構成

定期的にデータ取得のためにCakePHP1.3でシェル機能を利用

定期的にデータを取得する行為をするために、はじめてシェル機能を使ってみたのでメモ。 * ス

記事を読む

no image

iPhoneアプリ開発 芳名帳アプリ作成(6) -写真に保存-

* 今までの流れ - -[http://pplace.jp/2013/06/1531/:title=

記事を読む

no image

mailtoリンクの件名や本文の文字化け -N-02Aのケース-

* mailtoリンクの仕様 携帯電話用のWebサイトではmailtoリンクを使うことが多いと思い

記事を読む

no image

iPhoneアプリ開発 - touchesBeganとUITapGestureRecognizerの差(タッチとタップ) –

「画面にある画像を移動させたい」とか、「画面に線を書きたい」ということがあるかと思います。 ぐぐると

記事を読む

no image

Selenium2.0でUIテスト(2) -Rubyでやってみよう-

前回は、Selenium + PHPを試しました。 今後はRubyでやってみようということでSele

記事を読む

Selenium2.0でUIテスト(1) -まずはPHPでやってみる-

久しぶりにSeleniumを触ってみました。 Selenium2.0から色々と変わったみたいで少々

記事を読む

no image

CakePHP1.2から1.3への変更作業

CakePHP1.2から1.3への変更作業でおこなったことまとめ。 思ったよりも面倒なので、誰かの

記事を読む

広告

Comment

  1. aki より:

    私もモデル・キャッシュではまった(>_<
    はまった時を、思い出しました。

Message

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

次のHTML タグと属性が使えます: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <s> <strike> <strong>

広告

no image
[感想] Effective Objective-C 2.0 ☆☆☆☆★(4.5)

* 構成 - 第1章 Objective-Cに慣れる -

no image
[感想] iOSアプリテスト自動化入門 ☆☆☆(3.0)

* 構成 - Chapter 1 テスト自動化への取り組み

DeployGateを試してみた(iOS編) -DeployGateがiOSに対応-

今までのDeployGate - -[http://pplace.

iPhone/iPadアプリを開発するためにやったこと

今までに、iPhoneを3本ほどリリース((リリースしたアプリは全て1

no image
ターミナルでgitのコマンドを補完したりブランチ名を表示する – macでgitを便利に使うために –

* やりたいこと macのターミナルでgitをいじっていると -今の

→もっと見る

PAGE TOP ↑