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_’);
広告
関連記事
-
iPhoneアプリ開発 芳名帳アプリ作成(3) -名前を書けるようにする-
* 今までの流れ - -[http://pplace.jp/2013/06/1531/:title=
-
githubを使っての開発(2) -masterブランチにマージ-
前エントリーでgithub-flowをもとにした流れを書いたのですが、その中のマージについてもう少し
-
iPhoneアプリを開発してての疑問 -教えてエライ人!-
MacでiPhoneアプリを開発してて疑問に思ったのの解決してないことを列挙。 知識不足をさらけ出し
-
ターミナルでgitのコマンドを補完したりブランチ名を表示する – macでgitを便利に使うために –
* やりたいこと macのターミナルでgitをいじっていると -今のブランチってなんだっけ? -g
-
Jenkins + DeployGate(2) -DeployGateにアプリをアップ!-
DeployGateを使ってますか? 継続的にDeployってますか? TestFlightの
-
Google Appsで独自ドメインメールの利用
独自ドメインでメアドを持ちたかったのでGoogle Appsを利用してみました。 その各種設定の覚
-
さくらのVPSでJenkins -執事さんとご対面-
さくらのVPSを利用している方は多いかと思います。 私も、自分で遊ぶ用(開発用)として借りてみまし
-
jQueryMobileでカレンダー表示 -DateBoxプラグインの利用-
スマートフォン対応をしているとカレンダーの表示の仕方をスマートフォンらしくしたいことがあると思います
-
iPhoneアプリ開発 -iOS6から変わったこと-
Deployment Targetを5.1にしていた時には気がつかなかったのですが、iOS6になって
-
CakePHP2系にTwigを導入
CakePHP2系でも慣れているSmartyを使おうと思ったものの、良いプラグインが見つからず断念。
Comment
私もモデル・キャッシュではまった(>_<
はまった時を、思い出しました。