質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

1回答

587閲覧

CakePHPでフォームのeditの書きかたを教えてください。

kumi-e

総合スコア5

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

0クリップ

投稿2019/08/21 01:36

編集2019/08/21 02:47

前提・実現したいこと

初めまして。まだ勉強を始めて間もないものです。勉強不足だとは思いますが、どなたかお力を貸していただけませんでしょうか。
CakePHPで「タイトル」「内容」「作成者」の画面から、editでテーブルに反映させたいのですが、「作成者」の名前だけがフォームにきちんと入力してもテーブルに反映されません。
宜しくお願い致します。
わかりづらい文章で申し訳ありません。

発生している問題・エラーメッセージ

作成者が登録、表示されません。また、エラーメッセージは出てはいません。

<?php App::uses('AppController', 'Controller'); class PostsController extends AppController { public function index() { $posts = $this->Post->find('all'); $this->set('posts',$posts); } public function add() { if ($this->request->is('post')) { if($this->Post->save($this->request->data)) { $this->Session->setFlash('登録されました'); return $this->redirect(array('action' => 'index')); } } } public function edit($id = null) { if ($this->request->is(array('post','put'))) { if ($this->Post->save($this->request->data)) { $this->Session->setFlash(__('保存しました')); return $this->redirect(array('action' => 'index')); } else { $this->Session->setFlash(__('保存できませんでした')); } } else { $options = array('conditions' => array('Post.'. $this->Post->primaryKey => $id)); $this->request->data = $this->Post->find('first',$options); } } public function delete($id = null) { if ($this->repuest->is('post')) { if ($this->Post->delete($id)) { $this->Session->setFlash(__('削除できました')); }else{ $this->Session->setFlash(__('削除できませんでした')); return $this->redirect(array('action' => 'index')); } }
view <html> <meta charset="utf-8"> <body> <table> <tr> <th>ID</th> <th>title</th> <th>本文</th> <th>作成者</th> <th>操作</th> </tr> <tr> <?php foreach ($posts as $post) { ?> <tr> <td><?php echo $post['Post']['id']; ?></td> <td><?php echo $post['Post']['title']; ?></td> <td><?php echo $post['Post']['body']; ?></td> <td><?php echo $post['Post']['writer']; ?></td> <td><?php echo $post['Post']['data']; ?></td> <td><?php echo $post['Post']['data_taime']; ?></td> <td><?php echo $this->Html->link(__('編集'),array('action' => 'edit', $post['Post']['id'])); ?> <?php echo $this->Form->postLink(__('削除'),array('action' => 'delete', $post['Post']['id']), array('confirm' => __('削除してよろしいですか?'))); ?></td> </tr> <?php } ?> </table> </body> </html>
model <?php App::uses('AppModel','Model'); class Post extends AppModel { public $validate = array( 'title' => array( 'notblank' => array( 'rule' => array('notblank'), 'message' => 'タイトルを入力してください。', ), 'maxLength' => array( 'rule' => array('maxLength',30), 'message' => 'タイトルは30字以内で入力してください。', ), ), 'body' => array( 'notblank' => array( 'rule' => array('notblank'), 'message' => '本文を入力してください。', ), ), 'writer' => array( 'notblank' => array( 'rule' => array('notblank'), 'message' => '本文を入力してください。', ), 'maxLength' => array( 'rule' => array('maxLength',10), 'message' => 'タイトルは10字以内で入力してください。', ), ), ); } ?>
edit.ctp <?php echo $this->Form->create('Post'); echo $this->Form->input('id'); echo $this->Form->input('title'); echo $this->Form->input('body'); echo $this->Form->input('writer'); echo $this->Form->end('送信'); ?> var_dump($this->request->data);exit;
Nr Query Error Affected Num. rows Took (ms) 1 SELECT `Post`.`id`, `Post`.`title`, `Post`.`body`, `Post`.`作成者`, `Post`.`作成日`, `Post`.`更新日` FROM `fencer`.`posts` AS `Post` WHERE 1 = 1 12 12 0

試したこと

if ($this->Post->save($this->request->data)) {
のPostをwriterに変えたらエラーになってしまいました。

イメージ説明

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2019/08/21 01:40

これだけだと「requestに作成者が入ってないんじゃないか」くらいしか言えません。 requestを送るフォームのHTML(またはview) そこにどういうデータが表示されているか、 $this->request->data の内容(dd()で良いです) データベースの定義(CREATE TABLE文が良いです)を質問本文に追記してください。
m.ts10806

2019/08/21 01:41

また「作成者だけがうまく反映されません。」がどういう状況なのか詳細に記載いただければと思います。
kumi-e

2019/08/21 01:55

m.ts10806様 コメントありがとうございます。 説明不足で大変申し訳ありません。 追記したのでどうか宜しくお願い致します。
m.ts10806

2019/08/21 02:11

細かくて申し訳ないですが、もうちょっと調整いただきたいです。 ・ファイルが違うのでしたらコードブロックはわけてもらいたいです ・viewファイル冒頭に何かいます [å]<html> ・テーブル定義を提示してください(要は対象のテーブルを作成するためのSQLのCREATE TABLE文です。) ・edit()でdd($this->request->data);もしくはvar_dump($this->request->data);exit;を書いて結果を教えてください。 懸念点 ・viewには画面表示しているだけでフォーム送信できる情報が何もないのでは?
kumi-e

2019/08/21 02:23

m.ts10806さま ご丁寧にありがとうございます。 これが私の今の全知識です。 無知で申し訳ありません。
kumi-e

2019/08/21 02:24

あと、var_dump($this->request->data);exit; は何も起きませんでした。
m.ts10806

2019/08/21 02:27

えーっと・・ ・posts というDBのテーブルはどのように作りましたか?例えばマイグレーションを実行したとか。そのマイグレーションのファイルとかでも良いです。要はpostsというテーブルにどういうカラムがあって、それぞれどういう型で、というのが知りたいので。 ・var_dump($this->request->data);exit;はそこ(.ctp)ではないです。あくまで「登録処理をする際にちゃんと送信したいデータがきているか」の確認をしたいので、PostsController のedit()の冒頭に仕掛けてください。
kumi-e

2019/08/21 02:38

DBはMyadminで作りました。id,title,body,作成者、作成日、更新日のカラムがあります。 var_dump($this->request->data);exit;をPostsController のedit()の冒頭に書着なおしたのですが何も起きませんでした。 話がずれていたら申し訳ありません。
m.ts10806

2019/08/21 02:41

>DBはMyadminで作りました。 phpMyAdmin ですね。了解です。 ではphpMyAdminでpostsテーブルの「構造」タブを開いて画面キャプチャをご提示ください。 そこにテーブルの定義が表示されているはずです。 > var_dump($this->request->data);exit;をPostsController のedit()の冒頭に書着なおしたのですが何も起きませんでした。 んーおかしいですね。edit()が実行されたら必ず通るはずですが。 ↓のようにしてますよね? public function edit($id = null) { var_dump($this->request->data);exit; if ($this->request->is(array('post','put'))) {
kumi-e

2019/08/21 02:48

画像ご確認お願い致します。 public function edit($id = null) { var_dump($this->request->data);exit; if ($this->request->is(array('post','put'))) になっていますが、何も起きません。
m.ts10806

2019/08/21 02:50

状況確認できました。先だって回答もしています。 var_dump()通らないのが良く分かりませんね。送信ボタン押して確認しましたか? 想定では送信ボタン押したときにそこで処理が止まって送信された入力情報が出力されると思ったんですが。 もしくは、編集処理であるedit()ではなくadd()の方の話だったか・・
kumi-e

2019/08/21 02:53

ありがとうございます。 var_dump()、送信ボタン押してもそのままテーブル表示に切り替わります。
m.ts10806

2019/08/21 02:57 編集

exit;をつけていたらそこで処理は中断しますので、exit;は必要ですね。 echo 1; //出力される exit; echo 2; //出力されない
guest

回答1

0

ベストアンサー

SELECT Post.id, Post.title, Post.body, Post.作成者, Post.作成日, Post.更新日 FROM fencer.posts
id,title,body,作成者、作成日、更新日のカラムがあります。

テーブル定義と上記からすると全角文字でカラムが作られていることになります。
ということは、writerという名前で入力コントロールを作ったのでしたら、テーブルに合致するカラム名がないので「更新されない」というのは合点がいきます。

CakePHPのフォームヘルパーでどこまでできるのか分かりませんが
入力フォームを下記のようにするか

php

1echo $this->Form->input('作成者');

カラム名をwriterという名前に変更するか、どちらかで対応するときちんと更新されるのではないでしょうか。

※できればカラム名を半角に統一したほうが良いです。

投稿2019/08/21 02:45

編集2019/08/21 02:48
m.ts10806

総合スコア80850

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kumi-e

2019/08/21 03:09

とても丁寧に、噛み砕いて教えていただきありがとうございました。 おかげで、きちんと解決できました。 きめ細やかなアドバイスもありがとうございます。 これでまた先に進めます。 ありがとうございました。
m.ts10806

2019/08/21 03:46

ヒントになったようで何よりです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問