Datamapper ORM / Codeigniter - - - проверить отношение

у меня есть следующая БД:


CREATE TABLE users
(
id BIGINT NOT NULL AUTO_INCREMENT,
PRIMARY KEY (id)
);

CREATE TABLE likes
(
id BIGINT NOT NULL AUTO_INCREMENT,
user_id BIGINT,
idea_id BIGINT,
PRIMARY KEY (id)
);

CREATE TABLE ideas
(
id BIGINT NOT NULL AUTO_INCREMENT,
PRIMARY KEY (id)
);

пользовательская модель:

// --------------------------------------------------------------------
// Relationships
// --------------------------------------------------------------------

public $has_many = array( 'like' , 'idea' , 'comment' );

// --------------------------------------------------------------------
// Validation
// --------------------------------------------------------------------

var $validation = array(
    'username' => array(
        'label' => 'Username',
        'rules' => array('required', 'trim', 'unique', 'min_length' => 3 )
    ),
    'password' => array(
        'label' => 'Password',
        'rules' => array('required', 'trim', 'min_length' => 3 ,'encrypt' )
    )
);

модель идеи:

public $has_one = array('user');

public $has_many = array('like');

// --------------------------------------------------------------------
// Validation
// --------------------------------------------------------------------

public $validation = array(
    'user' => array(
        'rules' => array('required')
    )
);

как модель:

// Relationships
// --------------------------------------------------------------------

public $has_one = array( 'user' , 'idea' );

// --------------------------------------------------------------------
// Validation
// --------------------------------------------------------------------

var $validation = array(
    'user' => array(
        'rules' => array('required', 'unique_pair' => 'idea' )
    ),
    'idea' => array(
        'rules' => array('required')
    )
);

как контроллер

    $idea = new Idea(1);

    $user = new User(1);

    $like = new Like(); 

    if( !$like->save( array( $idea , $user ) ) )
    {
          echo $like->error->all;
    }
    else
    {
      echo "ok";    
    }   

Проблема в том, что я всегда получаю ОК, а лайки сохраняются в базе данных и не проверяются.

я хочу, чтобы оба поля ( user_id , idea_id ) были уникальными


person ItsMKO    schedule 26.08.2012    source источник


Ответы (1)


Добавьте свойства $model и $table в модели, это поддержит отношения. После этого подтвердите свой foreign keys. Помните единственное число для имени модели и множественное число для имени таблицы.

public $model = 'user';
public $table = 'users';

....
public function __construct($id = NULL) {
    parent::__construct($id);
}
person rigobcastro    schedule 18.04.2013