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

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

ただいまの
回答率

89.07%

DBに保存できない..

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 715

rumi

score 9

Chat形式のメッセージ内容をDBに保存するため下記のPHPを記載しています。テーブルtbl_messagesにarrayの内容をinsertしたいのですが、実行してもDBに保存されません。

色々試したところ、description以外はDBに保存できる様ですが、descriptionだけnullになってしまう感じが、問題のようです。(descriptionはtextareaでメッセージを入力する部分です)
HTML側も下記に記載しておりますが、問題点がお分かりかたはご指摘いただけると幸いです。

public function sendMessage(){

        extract($this -> reqData);
        $desc = (isset($description) && trim($description) != null) ? trim($description) : null;
        if ($desc != null) {

                    $lastId = $this -> db -> insert('tbl_messages',
                    array(
                            'senderId'    => $this->sessUserId,
                            'receiverId'  => ($this->sessUserId == $this->$receiverID['provider']['userId']) ? $this->$receiverID['provider']['userId'] : $this->$receiverID['userId'],
                            'type'        => 'workroom',
                            'subject'     => $this->proj['title'] . " - Workroom conversation",
                            'description' => $desc,
                            'createdDate' => date('Y-m-d H:i:s'),
                            'projectId'   => $this->proj['id'],
                            ))->lastInsertId();


                if ($lastInsertId > 0) {

                        if ($this->dataOnly) {
                                return array(
                                        'status' => 1,
                                        'msg'    => 'Success',

                                );
                        } else {
                                echo json_encode(array(
                                        'status' => 1,
                                        'msg'    => 'undefined',

                                ));
                        }
                    }
                }

        return $html;
    }
<form class="chat-form" id="sendMsg">
                                                    <div class="form-group">
                                                        <textarea name="message" class="form-control" rows="4" id="description"
                                                        name="description"
                                                        placeholder="メッセージを入力..."
                                                        data-validation="validateDescription"
                            data-validation-error-msg="Please check description carefully."></textarea>
                                                    </div>
                                                    <div class="form-group text-right">
                                                        <input type="hidden" name="action" value="method"/>
                                                        <input type="hidden" name="method" value="sendMessage"/>
                                                        <button type="submit" class="btn btn-link" data-ele="sendMessage">
                                                            送信
                                                        </button>
                                                    </div>
                                                </form>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • miyahan

    2017/10/22 11:13

    自作クラスの一部を切り出して見せられても何をしているのかさっぱりわからないので答えられません。今回の不具合を再現するのに最低限必要なコードを抜き出して提示すると回答が得られやすいと思いますし、その過程で原因に気づくことも多々あります。

    キャンセル

  • rumi

    2017/10/22 13:00

    こちらアドバイスありがとうございます。Arrayの内容のうち、descriptionがDB保存時にnullになってしまいます。HTMLのコードも追記いたしました。descriptionはtextareaの部分を参照しております。もしお分かりでしたら、宜しくお願い致します。

    キャンセル

  • masaya_ohashi

    2017/10/23 10:26

    確認ですが、そもそもdbという変数はなんのオブジェクトですか?PDO?PDOにinsertなんてメソッド無いような…

    キャンセル

回答 2

0

  • if ($desc != null) {を通っている以上、実際に$descはnullではない
  • 他の値は保存されているのでinsertは成功している

以上二点から推測されるのは、DBのテーブルのデータ定義のdescriptionの「スペルミス」かと思います。コードはdescriptionという値を渡して保存しようとするが、DBのカラム名が間違っているならそこにデータは保存されません。一度tbl_messagesの定義を見直してみてください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/10/23 10:22 編集

    コメントいただき、ありがとうございます。
    tbl_messages のカラム名を見直して見ましたが、description にスペルミスはなかったです。

    キャンセル

check解決した方法

-2

正確な部分はわかっていませんが、色々触っているうちに、DBに保存できるようになっていました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 89.07%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る