トップページphp
1001コメント305KB

【PHP】フレームワーク CakePHP 8ホール目【1.3】

レス数が1000を超えています。これ以上書き込みはできません。
0001nobodyさん2010/03/18(木) 10:00:59ID:6+kHM8kH
CakePHPは、Ruby on Railsの概念の多くを取り入れた、Rails流の高速開発とPHPの機動性を兼ね備えたフレームワークです
CakePHPから派生したLithium(li3)も専スレできるまではここでどうぞ
質問するときはCakePHPのバージョンを書きましょう

※sage推奨
テンプレは>>1-5くらい

■本家
http://www.cakephp.org/
APIドキュメント
http://api.cakephp.org/
the Bakery
http://bakery.cakephp.org/
CakeQs
http://cakeqs.org/
CheatSheet (PDF)
http://cakephp.org/files/Resources/CakePHP-1.2-Cheatsheet.pdf
github - cakephp
http://github.com/cakephp

■日本語公式
http://cakephp.jp/
フォーラム
http://cakephp.jp/modules/newbb/
cookbook(マニュアル)
http://book.cakephp.org/ja
09399232010/07/21(水) 14:28:11ID:???
>>938
用意されていないのですね・・・
自前で仕組みを作ってみることにします。
0940nobodyさん2010/07/21(水) 14:29:53ID:???
>>939
あ、でも任意のディレクトリを指定できたかも?
調べてみて
09419232010/07/21(水) 14:36:20ID:???
>>940
保存場所を任意のディレクトリにはできるようです
キャッシュ保存前に保存場所を切り替えてディレクトリに分けて保存するという
やり方もありそうですが、結局読み出しの時にそのディレクトリを指定してあげなきゃ
いけないので、どちらにせよその辺は自前で用意しなきゃいけませんね・・・
09429352010/07/21(水) 14:36:36ID:???
あちょっと違ってた。
ビューのキャッシュのファイル名など決めてんのはキャッシュヘルパーの仕事すね。
09439352010/07/21(水) 14:52:27ID:???
>>937
そんなこともあったんだ。

俺が不安に思ってたのは、キャッシュのファイル名はurlをInflector::slugにかけて作ってるから
下手すると、違うページなのに同一ファイル名のキャッシュができてしまう可能性があること。
1.3のInflector::slugはちょっと良くなったみたいだけど、どうなんだろ。
0944nobodyさん2010/07/21(水) 14:55:11ID:???
>>943
URLごとにキャッシュファイル作成するからそれはない
Inflector::slugの件は、PCREライブラリの設定で、回避可能(確認したのはv1.3.0)
0945nobodyさん2010/07/21(水) 14:56:13ID:???
ビュー内で、そのビューが格納されている
フォルダ名(コントローラー名の頭文字を小文字にしたやつ)
を簡単に取得するにはどうしたらいいでしょうか

$this->name で名前がとれましたが、頭文字が大文字の
ため、毎度変換しないといけないので、もっと簡単にとれれば
と思った次第です
0946nobodyさん2010/07/21(水) 15:11:56ID:???
>>945
つ Inflector
0947nobodyさん2010/07/21(水) 15:45:21ID:???
みなさん、Cakeに移行するまでに使っていたclassや関数ってどうしてます?
コンポーネントやヘルパーを作って完全にCakeに移行します?

Cake用に書き換えるとCake以外で使う時、使えなくなるなって思い
どこまで移植するか悩みます。
0948nobodyさん2010/07/21(水) 16:16:24ID:???
ベンダーにいれろよ
0949nobodyさん2010/07/21(水) 16:32:57ID:???
ベンダーですか・・。DB接続あるし、どうしようか悩むんですよね。
0950nobodyさん2010/07/21(水) 16:39:38ID:???
迷ってる暇があるなら、
さっさとcakePHP用に移行したほうが幸せになれると思うけど。

cakePHPのファンクションを使用しなければ、
他のフレームワークに移行したところで影響は少ないと思う。
0951nobodyさん2010/07/21(水) 16:52:33ID:???
DB接続をハードコーディングしてあるクラス
カラスもつつかないごみじゃない?
0952nobodyさん2010/07/21(水) 18:00:11ID:???
>>950
さっきから小一時間やっていたのですが、
ようやく1つの関数を移行できました・・。

いくらやってもデータが追加できなかったのですが、
素のSQL文って INSERT INTO table_name ('name') VALUES ('aaa')
でもインサートされて、IDはオートインクリメントで連番が付けられますが、
Cakeの場合は、IDフィールドを指定しないと追加されません。

$values["Test"] = array(
'id' =>'', // これが必要
'name'=>$name
)

こういうCake特有の仕様が物凄く面倒なんですよね・・・
0953nobodyさん2010/07/21(水) 19:49:47ID:???
え?
0954nobodyさん2010/07/21(水) 19:56:15ID:???
これがPHP脳ですか?
0955nobodyさん2010/07/21(水) 20:24:57ID:???
本当にゴミ以下のソースで藁
0956nobodyさん2010/07/21(水) 20:27:02ID:???
そんな無駄な資産捨てちまえってww
0957nobodyさん2010/07/21(水) 20:33:16ID:???
おまえらにも親の肩身のタオルケットくらいあるだろうが!
0958nobodyさん2010/07/21(水) 21:39:58ID:???
いちいち変数に値が存在するか否かissetで調べないと
Undefined variableエラーが出るんだけど、
issetで調べない方法はゴミソースで良いの?
0959nobodyさん2010/07/21(水) 23:41:22ID:???
>>958
getデータはrouting使うと、issetやらis_numericやらは省略できる
0960nobodyさん2010/07/21(水) 23:44:28ID:???
emptyで
0961nobodyさん2010/07/22(木) 00:33:00ID:???
>>958
お前は何を言ってるんだ?
それがCakePHPの所為だとおもってるんなら今すぐやめたほうがいい
0962nobodyさん2010/07/22(木) 01:07:55ID:???
array地獄をやめてclassに移行してほしい。
生成した側は構造が分かっているはずだけど、
依存するのは避けたいから利用側で確認しないわけにはいかない。
0963nobodyさん2010/07/22(木) 01:41:18ID:???
formヘルパーのtimeで
24時間以降を、午前1時=25:00
というふうに30時くらいまで追加する方法ってないでしょうか
0964nobodyさん2010/07/22(木) 01:46:11ID:???
継承して数値ずらせばいいだけ
0965nobodyさん2010/07/22(木) 02:05:46ID:???
>>961
止めるって何を?
0966nobodyさん2010/07/22(木) 02:35:07ID:???
人生以外ないだろ
0967nobodyさん2010/07/22(木) 12:00:40ID:???
CakePHPは人生
0968nobodyさん2010/07/22(木) 14:36:53ID:+voqy8bn
AというコントローラーでモデルをA・Bと指定してるとします。
findの場合、$this->B->find でBのモデルに対するデータを取得できますが、
これをページネーションでするにはどうすればいいのでしょうか?
$this->B->paginate()では駄目でした
0969nobodyさん2010/07/22(木) 14:46:06ID:???
$this->B->paginate(’B’)

でいけました。スレ汚しすみません。。
0970nobodyさん2010/07/22(木) 15:50:14ID:???
解決はや!
0971nobodyさん2010/07/22(木) 18:41:51ID:???
>>958
あたまに@つけろ
0972nobodyさん2010/07/22(木) 18:44:59ID:???
@推奨すんなw
あとcakePHPとは関係がない。よそでやれ
0973nobodyさん2010/07/22(木) 19:52:23ID:???
DBのカウンタのフィールドを+1したい(SQL で書くと counter + 1 )のだけど
cakePHPのモデルだとどう書くのですか?
0974nobodyさん2010/07/22(木) 19:56:52ID:???
>>973
インクリメントビヘイビアというのがある
それをそのまま使うか、それを参考に
0975nobodyさん2010/07/22(木) 20:43:44ID:???
>>974
Thanx!!
検索用語が難しくて全然探せなかったので助かりました。

$this->Article->doIncrement($id, 1, 'votes');

Increment Behavior (Articles) | The Bakery, Everything CakePHP
http://bakery.cakephp.org/articles/view/increment-behavior

検索用: フィールド +1 カウンター SQL field +1 counter

と思ってソースみたら、結局findByIdしたものを +1 しているからSQLは2回
投げる気がする。それだったら意味ないっぽい。
上記リンクのコメントのリンク先にあるやり方の方が良さそうかな。
$content->updateAll(array(‘num_of_purchases’ => ‘num_of_purchases+1′)
0976nobodyさん2010/07/22(木) 20:44:53ID:???
または、これかな。

app_model.php

function UpdateHits($id)
{
//debug ($this->useTable);exit;
$FieldToInc = 'views';
$this->execute("UPDATE $this->useTable SET $FieldToInc=$FieldToInc+1 WHERE id=$id");
}
0977nobodyさん2010/07/22(木) 21:22:06ID:???
単純にSQL文で書けば
UPDATE table_name SET count=count+1

なのに、やけにめんどくさいよね。仕様だから仕方ないけど
0978nobodyさん2010/07/22(木) 22:04:37ID:???
そう思ったらquery()つかえばよろし
0979nobodyさん2010/07/22(木) 22:55:12ID:???
まぁ、そこら辺はCakeは遠回りするからね。
シンプルなものなら直書きでも良いんじゃないか。
0980nobodyさん2010/07/23(金) 01:12:40ID:???
>>977
それは排他制御が・・

Cakeのは大丈夫なのか、といわれると知らんが。
0981nobodyさん2010/07/23(金) 01:41:37ID:???
saveしようとして
$dat = array('id'=>null,'txt'=>'AAA')
を table->save($dat)
としたら、
クエリの内容が
INSERT INTO "table" ("id", "txt") VALUES (NULL,'AAA')
となってしまって、
idはnullじゃ駄目なんだよ。とエラーが返ってきます。

通常idがnullだと、クエリからidは外してくれるんですが
何故かidが外れません

何か原因で考えられる事はあるでしょうか
0982nobodyさん2010/07/23(金) 01:43:22ID:???
ならidの辞書型自体を指定しなけりゃいいんじゃね?
0983nobodyさん2010/07/23(金) 02:03:22ID:???
確かにそうなのですが、
これまではidを指定していても自動で外してくれていたんです。

特定の場所だけで発生しています
0984nobodyさん2010/07/23(金) 02:06:15ID:???
これまでって何だよ
0985nobodyさん2010/07/23(金) 02:10:46ID:???
エスパー召喚魔法唱えてるんだろ。
人間に方は放置しておk
0986nobodyさん2010/07/23(金) 02:13:24ID:???
>>981
>>952じゃないの?
0987nobodyさん2010/07/23(金) 02:17:47ID:???
いっそソース一式全部晒してくれれば
バグを見つけてくれる人もいるだろう
0988nobodyさん2010/07/23(金) 02:33:57ID:???
どうでもいいけどチュートリアルくらいはこなしてから人に聞いてるんだろうな
0989nobodyさん2010/07/23(金) 02:37:40ID:???
モデル周りのマニュアルちゃんと読めばなんてこと無いことを苦労してる気がする。
0990nobodyさん2010/07/23(金) 02:39:23ID:???
>>980
この場合の排他制御ってどういう意味?
MySQLならUPDATEしていれば問題ないよね?

incrementの方は排他制御的に問題あると思うけど
0991nobodyさん2010/07/23(金) 03:09:35ID:???
そもそも+1したいってなんなの?
システム変更でデータ移行するから一気に+1したいのか
取り出した値を常に+1したいのか
あーめんどくせーどうでもいいや

ここ最近の質問って全部同一人物だろ
ぐだぐだいってないでCakeやろうと思ったなら
オフィシャルやらチュートリアルやらAPIのドキュメントやら読めよ
嫌なら何も始めるな
0992nobodyさん2010/07/23(金) 04:09:29ID:???
>>991
同一人物じゃないが
UPDATE table_name SET count=count+1 をしたい

>ぐだぐだいってないでCakeやろうと思ったなら
>オフィシャルやらチュートリアルやらAPIのドキュメントやら読めよ

どこに書いてあるの? どこにも書いてない、できないから上記の答えになっているんだろ?
日本語が理解できないならまず日本語を勉強してこいよ
0993nobodyさん2010/07/23(金) 04:30:20ID:???
UPDATE 〜 のSQL文書いたのは俺だけどなw

てか、count+1する場面って結構あると思うけどな。
在庫管理にカウンターに投稿数の加算とか。

チュートリアル見て質問してるだろうけど、
翻訳が変だったり、不十分だったりするから人に聞くんでしょ。
0994nobodyさん2010/07/23(金) 08:36:28ID:???
>>992
ならそれをModel->query()で問題ないっていってんだろ
しつけーんだよアホか
0995nobodyさん2010/07/23(金) 08:49:45ID:???
「cakephp increment」で検索かけるとすぐに件のビヘイビア見つかって解決。
検索できるようになろうね。

それに対して>>977
>単純にSQL文で書けば
>UPDATE table_name SET count=count+1
>
>なのに、やけにめんどくさいよね。仕様だから仕方ないけど

なんだけど、これ俺勘違いして質問者が言ってると思ってた
だからそう思うならquery()で書けばいいって書いたわけ。
0996nobodyさん2010/07/23(金) 08:53:56ID:???
次スレ立ててくるわ
0997nobodyさん2010/07/23(金) 09:17:12ID:???
【PHP】フレームワーク CakePHP 9ホール目【v1.3】
http://pc11.2ch.net/test/read.cgi/php/1279844006/

どぞー
0998nobodyさん2010/07/23(金) 14:52:49ID:???
>>994
バカか?
queryでできることには誰も反論してないだろ。誰がどこでそれに問題があるって言ったと思っているんだよ。


マニュアル等に書いてないのも事実だろ?
まず日本語の読解能力つけろよ

そんな話はしてなくて今は排他処理のことを聞いているんだよ。
0999nobodyさん2010/07/23(金) 15:25:43ID:???
逆ギレの現場を見た

w
1000nobodyさん2010/07/23(金) 15:50:25ID:???
次いってみよー
10011001Over 1000Thread
このスレッドは1000を超えました。
もう書けないので、新しいスレッドを立ててくださいです。。。
レス数が1000を超えています。これ以上書き込みはできません。