0

Kohana (3.2) 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')
     );
  ...

ここで何が間違っているのか誰にもわかりませんか?どんな助けでも大歓迎です!

4

2 に答える 2

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

これが役立つことを願っています。

于 2012-12-01T10:57:34.767 に答える
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()
  );
  //...
于 2012-12-01T11:04:48.213 に答える