CakePhp使用Postgresql数据库插入问题

时间:2013-10-18 13:56:22

标签: cakephp cakephp-2.3

我有这个问题与cakephp我有一个表用户和配置文件,
profiles表有一个外键user_id,它引用users表中的id列

现在当我插入时,我首先为用户插入数据,然后从users表中检索最后插入的数据的id,然后将其传递给在profiles表中的user_id字段, 现在的问题是我收到了这个错误:

错误:SQLSTATE [22P02]:无效的文本表示:7错误:数组值必须以“{”或维度信息

这是数据插入的代码。

/*
* signup method
* @return void
*/
public function signup(){
    if($this->request->is('post')){                             
        $this->User->create();
        //Tweek to unset modified field.
        $user_data = array(
            'username' => $this->request->data['User']['username'],
            'password' => $this->request->data['User']['password'],
            'modified' => false             
        );  
        $user = $this->User->save($user_data);
        if(!empty($user)){
            //If the user was saved get the users id and pass to profile user_id foreign key
            $this->request->data['Profile']['user_id'] = $this->User->id;

            // Because our User hasOne Profile, we can access
            // the Profile model through the User model
            $profile_data = array(
                'user_id' => $this->request->data['Profile']['user_id'],
                'student_id' => $this->request->data['Profile']['student_id'],
                'first_name' => $this->request->data['Profile']['first_name'],
                'middle_name' => $this->request->data['Profile']['middle_name'],
                'last_name' => $this->request->data['Profile']['last_name'],
                'modified' => false
            );
            if($this->User->Profile->save($profile_data)){
                $this->Session->setFlash(__('Your Account has been successfully added.'));
                return $this->redirect(array('action' => 'login'));
            }
            $this->Session->setFlash(__('The user could not be saved. Please, try again.'), 'default', array(), 'register_error');
        }
    }

    $this->layout = 'custom_layouts/default';
    $data = array(
        'id' => 'signup',
        'title_for_layout' => 'Reservation . Sign up'
    );
    $this->set($data);  
}   


这是用户模型:

<?php   
App::uses('AuthComponent', 'Controller/Component');
App::uses('BlowfishPasswordHasher', 'Controller/Component/Auth');   

/**
 * User Model
 *
 */
class User extends AppModel {
    //Allow Model to use both users and profiles table
    public $uses = array('User', 'Profile');

    //Setting Models Association
    public $hasOne = array(
        'Profile' => array(
            'classname' => 'Profile',
            'order' => array('Profile.last_name' => 'ASC'),
            'dependent' => TRUE
        )
    );

    /**
     * Validation rules
     *
     * @var array
     */
    public $validate = array(
        'username' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'A username is required'
            ),
            'isUnique' => array(
                'rule' => 'isUnique',
                'message' => 'This username has already been taken.'
            )
        ),
        'password' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'A password is required'
            ),
            'minlength' => array(
                'rule' => array('minlength', '8'),
                'message' => 'Password should be 8 characters long'
            )
        )           
    );      

    public function beforeSave($options = array()){         
        //Hash passwords before saving to database          
        if(!empty($this->data[$this->alias]['password']) || isset($this->data[$this->alias]['password'])){
            $hashedPassword = Security::hash($this->data[$this->alias]['password'],"blowfish");
            $this->data[$this->alias]['password'] = $hashedPassword;
        }           
        return true;
    }       
}

这是个人档案模型:

<?php       
/**
 * User Model
 *
 */
class Profile extends AppModel {
    //Setting Models Association
    public $belongsTo = array(
        'User' => array(
            'classname' => 'User',
            'foreignKey' => 'user_id'
        )
    );

    //Data Validation
    public $validate = array(
        'student_id' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'A student id is required'
            ),
            'isUnique' => array(
                'rule' => 'isUnique',
                'message' => 'This student id has already been taken.'
            )
        ),

        'email' => array(
            'required' => array(
                'rule' => array('notEmpty'),
                'message' => 'An email is required'
            ),
            'isUnique' => array(
                'rule' => 'isUnique',
                'message' => 'This email address has already been taken.'
            )
        )
    );
}


这是Schema

1 个答案:

答案 0 :(得分:0)

您的字段可能是类型数组。你能发布数据库模式吗?

规则42和43似乎错了。时间戳数组?