How to override ATTR_DEFAULT_IDENTIFIER_OPTIONS in Models in Doctrine?

Posted by user309083 on Stack Overflow See other posts from Stack Overflow or by user309083
Published on 2010-04-05T08:27:03Z Indexed on 2010/04/05 8:33 UTC
Read the original article Hit count: 663

Filed under:
|

Here someone explained that setting a 'primary' attribute for any row in your Model will override Doctrine_Manager's ATTR_DEFAULT_IDENTIFIER_OPTIONS attribute: http://stackoverflow.com/questions/2040675/how-do-you-override-a-constant-in-doctrines-models

This works, however if you have a many to many relation whereby the intermediate table is created, even if you have set both columns in the intermediate to primary an error still results when Doctrine tries to place an index on the nonexistant 'id' column upon table creation. Here's my code:

//Bootstrap
// set the default primary key to be named 'id', integer, 4 bytes
Doctrine_Manager::getInstance()->setAttribute(
    Doctrine_Core::ATTR_DEFAULT_IDENTIFIER_OPTIONS,
    array('name' => 'id', 'type' => 'integer', 'length' => 4));

//User Model
class User extends Doctrine_Record
{
    public function setTableDefinition()
    {
        $this->setTableName('users');
    }

    public function setUp()
    {
        $this->hasMany('Role as roles', array(
            'local' => 'id',
            'foreign' => 'user_id',
            'refClass' => 'UserRole',
            'onDelete' => 'CASCADE'
        ));
    }
}

//Role Model
class Role extends Doctrine_Record
{
    public function setTableDefinition()
    {
        $this->setTableName('roles');
    }

    public function setUp()
    {
        $this->hasMany('User as users', array(
            'local' => 'id',
            'foreign' => 'role_id',
            'refClass' => 'UserRole'
        ));
    }
}

//UserRole Model
class UserRole extends Doctrine_Record
{
    public function setTableDefinition()
    {
        $this->setTableName('roles_users');
        $this->hasColumn('user_id', 'integer', 4, array('primary'=>true));
        $this->hasColumn('role_id', 'integer', 4, array('primary'=>true));
    }
}

Resulting error:

SQLSTATE[42000]: Syntax error or access violation: 1072 Key column 'id' doesn't exist in table. Failing Query: "CREATE TABLE roles_users (user_id INT UNSIGNED NOT NULL, role_id INT UNSIGNED NOT NULL, INDEX id_idx (id), PRIMARY KEY(user_id, role_id)) ENGINE = INNODB". Failing Query: CREATE TABLE roles_users (user_id INT UNSIGNED NOT NULL, role_id INT UNSIGNED NOT NULL, INDEX id_idx (id), PRIMARY KEY(user_id, role_id)) ENGINE = INNODB

I'm creating my tables using

Doctrine::createTablesFromModels();

© Stack Overflow or respective owner

Related posts about doctrine

Related posts about php