cakephp - 错误: Table posts for model Post was not found in datasource default

标签 cakephp cakephp-2.3

我正在尝试编辑我的用户信息,我所做的唯一更改是将下面的 Controller 函数中的 id 从 userID 更改为 id,因为我已经在数据库、模型和 View 中更改了此信息..

Public function useredit() {
            $this->User->id = $this->Session->read('Auth.User.id');
            $this->request->data = $this->Session->read('Auth.User.id');
            if ($this->request->is('post')) {
                if ($this->User->save($this->request->data)) {
                    $this->Session->setFlash(__('The User has been saved', true));
                    $this->redirect(array('action' => 'index'));
                } else {
                    $this->Session->setFlash(__('The User could not be saved. Please, try again.', true));
                }
            } else {
                $this->request->data = $this->User->read(null);
                isset($this->request->data['User']['password']);
            }
        }

但现在它告诉我错误:在数据源默认值中找不到模型帖子的表帖子。 这是我的模型:

<?php

App::uses('AppModel', 'Model');
App::uses('AuthComponent', 'Controller/Component');

class User extends AppModel {

    public $belongsTo = array('Group');
    public $actsAs = array('Acl' => array('type' => 'requester'));

    public function parentNode() {
        if (!$this->id && empty($this->data)) {
            return null;
        }
        if (isset($this->data['User']['group_id'])) {
            $groupId = $this->data['User']['group_id'];
        } else {
            $groupId = $this->field('group_id');
        }
        if (!$groupId) {
            return null;
        } else {
            return array('Group' => array('id' => $groupId));
        }
    }

    public $validate = array(
        'id' => array(
            'numeric' => array(
                'rule' => array('numeric'),
            ),
        ),
        'username' => array(
            'notempty' => array(
                'rule' => array('notempty'), 
                ),
        ),
        'password' => array(
            'notempty' => array(
                'rule' => array('notempty'),
            ),
        ),
        'name' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'Your name is required'
            )
        ),
        'surname' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'Your surname is required'
            )
        ),
        'address1' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'Please enter your first line of address'
            )
        ),
        'address2' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'please enter your second line of address'
            )
        ),
        'town' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'Please enter your town'
            )
        ),
        'postCode' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'please enter your postcode'
            )
        ),
        'dob' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'please enter your date of birth'
            )
        ),
        'emailAddress' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'please enter your email address'
            )
        ),
        'phoneNumber' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'please enter your phone number'
            )
        ),
        'mobileNumber' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'please enter your mobile number'
            )
        ),
        'group_id' => array(
            'numeric' => array(
                'rule' => array('numeric'),
            ),
        ),
    );

    public $hasMany = array(
        'Post' => array(
            'className' => 'Post',
            'foreignKey' => 'user_id',
            'dependent' => false,
            'conditions' => '',
            'fields' => '',
            'order' => '',
            'limit' => '',
            'offset' => '',
            'exclusive' => '',
            'finderQuery' => '',
            'counterQuery' => ''
        )
    );

    public function bindNode($user) {
        return array('model' => 'Group', 'foreign_key' => $user['User']['group_id']);
    }

    public function beforeSave($options = array()) {
         if (isset($this->data[$this->alias]['password'])) {
            $this->data[$this->alias]['password'] = AuthComponent::password($this->data[$this->alias]['password']);
        }
    }

}

我有遵循教程的帖子表,但我确实计划删除它们,因为它们与我的网站无关,但这与我收到此错误消息的事实有关

最佳答案

这是因为您在以下位置声明了 User 和 Post 之间的关系

public $hasMany = array(
    'Post'
);

如果您不需要此关系,您可以在用户模型 (user.php) 中删除此 $hasMany 关系。

关于cakephp - 错误: Table posts for model Post was not found in datasource default,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14857429/

相关文章:

CakePHP - 分页和排序二级关联

php - 是否可以在 CakePHP 的同一 View 中对两个不同的模型进行分页和排序?

php - CakePHP:如何在每个 Action 之前检查 session ?

javascript - Jshelper cakephp 未从元素获取数据

authentication - 拒绝 CakePHP 中的某些 Controller 操作权限

php - CakePHP 删除超过 5 天的记录

mysql - 基于 cakephp 中条件的模型中的foreignKey

cakephp - 在 CakePHP 中动态创建虚拟字段

mysql - 权限系统最有效/最简单的方法?

jquery - 如何在cakePHP中使用jquery