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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

CakePHP

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

Q&A

解決済

2回答

2295閲覧

cakephp3で外部キーが反映されない

JunZenpou

総合スコア24

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

CakePHP

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

0グッド

0クリップ

投稿2017/05/01 08:38

編集2017/05/01 11:12

###前提・実現したいこと
cakephp3でtwitterみたいなものを作っています。
テーブルはusers(id,name,username,password,email),posts(id,user_id,body,created)みたいな感じです。PostsTable.phpで、belongToを実装して、usersテーブルのidを、postsテーブルのuser_idで外部キーみたいな感じで挿入したいのですが、上手くいかず、どのユーザーのidでもuser_id=>0になってしまって、外部キーが反映されません。まだプログラミングを始めたばかりなので、ご教授いただけると幸いです。

###該当のソースコード

PostsTable.php

1<?php 2 3namespace App\Model\Table; 4 5use Cake\ORM\Table; 6 7class PostsTable extends Table { 8 public function initialize(array $config){ 9 $this->belongsTo('users',[ 10 'foreignKey' => 'user_id' 11 ]); 12 } 13 14} 15

sql

1CREATE TABLE `users` ( 2 `id` int(11) NOT NULL, 3 `name` varchar(255) NOT NULL, 4 `username` varchar(255) NOT NULL, 5 `password` varchar(255) NOT NULL, 6 `password2` varchar(255) NOT NULL, 7 `email` varchar(255) NOT NULL 8) ENGINE=InnoDB DEFAULT CHARSET=utf8; 9 10CREATE TABLE `posts` ( 11 `id` int(11) NOT NULL, 12 `user_id` int(11) NOT NULL, 13 `body` text NOT NULL, 14 `created` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP 15) ENGINE=InnoDB DEFAULT CHARSET=utf8;

PostsController.php

1<?php 2 3namespace App\Controller; 4 5class PostsController extends AppController { 6 7 8 // アクセスの権限処理 9 public function isAuthorized($user = null){ 10 $this->set('user',$user); 11 return true; 12 } 13 14 15 public function index(){ 16 $this->set('user',$this->Auth->user()); 17 $this->set('entity',$this->Posts->newEntity()); 18 $data = $this->Posts->find('all')->contain(['Users']); 19 $this->set('data',$data); 20 }

index.ctp

1<?php 2 echo "<br/><br/>"; 3 echo $this->Form->create($entity,['url'=>['action'=>'addRecord']]); 4 echo $this->Form->input('body',['placeholder'=>'140文字以内で入力','label'=>false]); 5 echo $this->Form->submit('ツイート'); 6 echo $this->Form->end(); 7 echo "<br/><hr>"; 8 ?> 9 10 <!-- ツイート表示 --> 11<?php 12 foreach ($data as $obj) { 13 echo "<pre>"; 14 print_r($obj->toArray()); 15 echo "</pre>"; 16 } 17

###試したこと
hasManyも試したのですが、上手くいきません。
宜しくお願いいたします。

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

sqlLog

1SELECT 2 Posts.id AS `Posts__id`, 3 Posts.user_id AS `Posts__user_id`, 4 Posts.body AS `Posts__body`, 5 Posts.created AS `Posts__created`, 6 Users.id AS `Users__id`, 7 Users.name AS `Users__name`, 8 Users.username AS `Users__username`, 9 Users.password AS `Users__password`, 10 Users.password2 AS `Users__password2`, 11 Users.email AS `Users__email` 12FROM 13 posts Posts 14 LEFT JOIN users Users ON Users.id = (Posts.user_id) 15

SQLのLogはこのように出ています。

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

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

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

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

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

popobot

2017/05/01 20:00

belongsToの設定はあっていると思います。formの内容をsaveする処理がありませんが、どのように保存しているのでしょうか
guest

回答2

0

自己解決

解決しました!ありがとうございました。

投稿2017/05/02 16:12

JunZenpou

総合スコア24

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

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

0

はっきりとしたことは不明ですが、idフィールドにAUTO_INCREMENTは設定されていますでしょうか?すべてのidはゼロになっているという事は有りませんでしょうか?

投稿2017/05/02 02:58

rik

総合スコア1151

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問