###前提・実現したいこと
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はこのように出ています。
回答2件
あなたの回答
tips
プレビュー