1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

Problema com relacionamento de tabelas no CakePhp

Este e o Model User

class User extends AppModel
{
public $name = 'User';
public $useTable = 'users';
public $displayField = 'name';
public $belongsTo = array(
        'Role' => array(
        'className' => 'Role',
        'foreignKey' => 'role_id'
    )
);
}

e este e o Model Role

class Role extends AppModel
{
public $name = 'Role';
public $useTable = 'roles';
public $displayField = 'name';
public $hasMany = array(
        'User' => array(
        'className' => 'User',
        'foreignKey' => 'role_id',
        'dependent' => false
    )
);
}

porém ao tentar fazer a seguinte requisição, o objeto Role é considerado nulo

$roles = $this->User->Role->find('list');

estas são as tabelas referenciadas pelos Models

CREATE TABLE IF NOT EXISTS `roles` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(100) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

CREATE TABLE IF NOT EXISTS `users` (
  `id` int(10) NOT NULL AUTO_INCREMENT,
  `email` varchar(50) DEFAULT NULL,
  `password` varchar(50) DEFAULT NULL,
  `name` varchar(50) DEFAULT NULL,
  `activation_code` varchar(50) DEFAULT NULL,
  `status` int(10) DEFAULT NULL,
  `created` datetime DEFAULT NULL,
  `modified` datetime DEFAULT NULL,
`role_id` int(10) DEFAULT NULL,
PRIMARY KEY (`id`),
 KEY `FK_users_roles` (`role_id`),
CONSTRAINT `FK_users_roles` FOREIGN KEY (`role_id`) REFERENCES `roles` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

alguém sabe informar o que está errado?

  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

0 resposta

Não é a resposta que estava procurando? Procure outras perguntas com as tags cakephp php model ou faça a sua própria pergunta.