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

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

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

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

Q&A

解決済

3回答

23254閲覧

SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'post_id' cannot be nullのエラーを解決したい

amaturePy

総合スコア131

CakePHP

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

0グッド

0クリップ

投稿2019/06/28 03:11

編集2019/06/28 03:31

CakePHP2でPost(投稿機能)_idに対応したコメント機能の実装の中でタイトル通りのエラーが出てしまい解決したいです。色々いじってしまったので見にくいかもしれませんが、私のコードにアドバイスを頂けたら大変嬉しいです。
よろしくお願いします。

<?php class CommentsController extends AppController { public $helper = array('Html','Form'); public function comment() { } public function add_comment($post_id) { if ($this->request->is('post')) { $post_id = $this->params['Post']['id']; $data['Comment']['post_id']=$post_id; if ($this->Comment->save($data)) { $this->Session->setFlash('Success!'); return $this->redirect('/Comments/comment/'); } else { $this->Session->setFlash('failed'); } } } } コード
コメントリンク表示画面 <?php foreach ($posts as $post ):?>   <tr> <td> <?php echo $this->Html->link($post['Post']['title'],array('action'=>'view',$post['Post']['id']));?> </td> <td> <?php echo ($post['Post']['message']);?> </td> <td> <?php echo $this->Html->link('Comment',array('controller'=>'Comments', 'action'=>'comment', $post['Post']['id']))?> <!-- <?php echo $this->Html->link('Retweet',array('controller'=>'Retweets', 'action'=>'getTweet', $post['Post']['id'], $post['Post']['message']))?> --> </td> </tr> コード
コメント入力画面 <h2>Add Comments</h2> <?php echo $this->Form->create('Comment', array('url'=>'add_comment/' .$this->params['pass'][0])); echo $this->Form->input('message', array('row'=>3)); echo $this->Form->end('post comment'); ?> コード

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

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

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

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

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

guest

回答3

0

ベストアンサー

コードにアドバイス・・というより「エラーを読みましょう」ですね。

特に今回はエラーメッセージにそのまま原因が書かれていますよ。
(前の質問の流れからすると「結局post_id来てないのでは」というツッコミになります)

投稿2019/06/28 03:58

編集2019/06/28 04:00
m.ts10806

総合スコア80838

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

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

amaturePy

2019/06/28 04:30

ありがとうございます。 エラーを一つずつ解決していくのが大切ですよね。 課題の期限があるため、焦って質問してしまいました。皆さまから頂いたご意見も再度復習させて頂きます。 post_idはビューファイルからコントローラーに引数としてadd_comment($post_id)で送ったつもりなのですが、、、
amaturePy

2019/06/28 09:13

以下のコードをコントローラーファイルに追加することでpost_idを取得することができました。 ``` if(isset($post_id)){ $data['Comment']['post_id']=$post_id; /////////ビューから値を取得 if ($this->Comment->save($data)) { $this->Session->setFlash('Success!'); コード ```
m.ts10806

2019/06/28 09:43

解決されたようで何よりです。
guest

0

データベースは何でしょう?
テーブル定義を確認しては?
NOT NULL 制約を外す

投稿2019/06/28 03:47

Orlofsky

総合スコア16415

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

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

amaturePy

2019/06/28 04:47

nullに設定するとエラーは消えますね。しかし、これでは値が入らないですよね? 理解不足で申し訳ありません。。。
Orlofsky

2019/06/28 04:56

NOT NULL 制約とはNULL値を許さない、という制約です。 実際にデータを入れて実行しては? >データベースは何でしょう? >テーブル定義を確認しては? を質問に追記しては?
amaturePy

2019/06/28 05:17

なるほど、、、調べて見ました。Notnull 制約というものがあるのですね。試してみます。
amaturePy

2019/06/28 09:13

以下のコードをコントローラーファイルに追加することでpost_idを取得することができました。 ``` if(isset($post_id)){ $data['Comment']['post_id']=$post_id; /////////ビューから値を取得 if ($this->Comment->save($data)) { $this->Session->setFlash('Success!'); コード ```
guest

0

なんのキーも設定せずに$post['Post']['id']が配列に与えられています

たとえばこう?

PHP

1array('controller'=>'Comments', 2 'action'=>'comment', 3 'post_id'=>$post['Post']['id'])

投稿2019/06/28 03:27

編集2019/06/28 03:29
yambejp

総合スコア114721

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

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

amaturePy

2019/06/28 03:57

ありがとうございます。 配列を与えるとundifine offsetというエラーが出たのでcomment.ctpに .$this->params['Post']['post_id']));と変更したところ、そのエラーは消えたのですが、「Too few arguments 」と引数が足らないとエラーが新しく発生しました。
amaturePy

2019/06/28 09:14

以下のコードをコントローラーファイルに追加することでpost_idを取得することができました。 ``` if(isset($post_id)){ $data['Comment']['post_id']=$post_id; /////////ビューから値を取得 if ($this->Comment->save($data)) { $this->Session->setFlash('Success!'); コード ```
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問