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

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

ただいまの
回答率

88.76%

cakephp3 DBにデータを登録したい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 2,769

zaltsu9

score 18

いつもお世話になっています。
DBにデータを登録したいのですが、
以下のエラーが発生し登録ができません。

ご教示のほどお願いいたします。

UsersテーブルとGroupsテーブルが存在し、
Usersのgroup_idがGruopsのidに対してforeign keyを設定しています。
Groupsにid=1のデータは存在しています。

  • エラーは①を行った際に発生しています。
Error: [PDOException] SQLSTATE[23000]: Integrity constraint violation: 1452 Cannot add or update a child row: a foreign key constraint fails (`cakephp`.`users`, CONSTRAINT `users_ibfk_2` FOREIGN KEY (`groups_id`) REFERENCES `groups` (`id`) ON DELETE CASCADE)
  • src/Controller/IndexController.php
$insert = [
  "id" => null,
  "companys_id" => 1,
  "groups_id" => 1,
  "account_id" => "test",
  "name" => "山田太郎",
  "email" => "test@test.test",
  "password" => $password,
  "disk" => $disk,
  "active" => 0,
  "role" => 1,
  "created" => $now,
  "modified" => $now
];

$trUsers = TableRegistry::get("Users");
$entity = $trUsers->newEntity();
$entity = $trUsers->patchEntity($entity, $insert);
$result = $trUsers->save($entity); //①
  • DB
>use cakephp;
>select * from groups;
+----+-------------+----------+---------------------+---------------------+
| id | companys_id | username | created             | modified            |
+----+-------------+----------+---------------------+---------------------+
|  1 |           1 | group1   | 2016-06-27 12:07:56 | 2016-06-27 12:07:56 |
+----+-------------+----------+---------------------+---------------------+
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

check解決した方法

0

解決しましたので以下記載いたします。
単純に私が設定したところで、①の部分をfalseに変えていたためとなります。
trueにすることでDBに値を登録することが出来ました。

ご確認いただいた方ありがとうございました。

  • src/Model/Entity/User.php
<?php
namespace App\Model\Entity;
use Cake\ORM\Entity;

class User extends Entity
{
    protected $_accessible = [
        '*' => true, //①
        'id' => false,
    ];

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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