2012-11-29 34 views
0

我有一個Kohana(3.2)ORM查詢生成器的奇怪問題,我無法弄清楚什麼是錯的。我收到「錯誤的表名」例外情況:Kohana ORM - 錯誤的表名

Database_Exception [ 1103 ]: Incorrect table name '' [ SELECT ``.* FROM `` JOIN `user_plugins` ON (`user_plugins`.`plugin_id` = ``.`id`) WHERE `user_plugins`.`user_id` = '9' ] 

正如您在查詢中看到的表爲空。

控制器:

$user = ORM::factory('user', Auth::instance()->get_user()->id); 

    if ($user->loaded()) 
    { 
    $result = $user->plugin->find_all(); 
    } 

用戶模型:

class Model_User extends Useradmin_Model_User 
    { 
    protected $_has_many = array(
     'plugin' => array('through' => 'user_plugins'), 
    ); 
    ... 

user_plugin模型

class Model_user_plugin extends ORM 
    { 
    protected $_belongs_to = array(
     'plugin' => array(), 
     'user' => array() 
    ); 
    ... 

插件模型

class Model_Plugin extends ORM 
    { 
    protected $_has_many = array(
     'user' => array('through' => 'user_plugins') 
    ); 
    ... 

任何人都知道這裏有什麼可能是錯的? 任何幫助非常感謝!

+0

什麼'Useradmin_Model_User'? PS。你爲什麼使用單數形式作爲關係名稱?它應該是'users','plugins'等。 – biakaveron

+0

謝謝你的迴應。我使用Mixu Useradmin模塊進行一些小修改(主要是爲了使它與Kohana 3.2兼容)。你可以在這裏找到源代碼:https://github.com/mixu/useradmin/blob/master/classes/useradmin/model/user.php – Pelmered

+0

你能告訴我var_dump($ user)'的結果嗎? – biakaveron

回答

3

這是用戶模型應該如何

class Model_User extends Useradmin_Model_User 
{ 
    protected $_has_many = array(
     'plugin' => array('model' => 'plugin', 'through' => 'user_plugins'), 
    ); 
... 

這是插件模式應該如何

class Model_Plugin extends ORM 
{ 
    protected $_has_many = array(
     'user' => array('model' => 'user', 'through' => 'user_plugins') 
    ); 

你不需要user_plugin模式可言,「user_plugins」在這兩種模式是指到表名稱,而不是型號名稱。只要確保你有表有以下字段user_plugins,

ID,USER_ID,plugin_id

我希望這有助於。

+1

我對這種植入方式做了一些更改,並且知道它即使沒有設置$ _object_name也能正常工作。我不是100%確定是什麼導致了這一點,但現在它起作用,所以我很高興:) – Pelmered

1

按照慣例,$_has_many必須始終使用複數名稱,除非您在目標模型中指定$_object_name中的名稱。因此,它應該是:

class Model_Plugin extends ORM 
{ 
    protected $_has_many = array(
    'users' => array('through' => 'users_plugins') 
); 
    //... 
class Model_User extends ORM 
{ 
    protected $_has_many = array(
    'plugins' => array('through' => 'users_plugins') 
); 
    //... 
class Model_user_plugin extends ORM 
{ 
    protected $_belongs_to = array(
    'plugin' => array(), 
    'user' => array() 
); 
    //...