首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >"NOT IN“Kohana ORM

"NOT IN“Kohana ORM
EN

Stack Overflow用户
提问于 2012-10-26 00:38:19
回答 1查看 1.6K关注 0票数 1

我有以下几个模型:

代码语言:javascript
复制
class Model_User extends ORM {

    protected $_primary_key = 'name';

    protected $_has_many = array(
        'repositories' => array(
            'model' => 'repository',
            'through' => 'repository_user',
        ),
    );
}

class Model_Repository extends ORM {

    protected $_primary_key = 'name';

    protected $_has_many = array(
        'users' => array(
            'model' => 'user',
            'through' => 'repository_user',
        ),
    );
}

我使用以下代码来获取未连接到存储库的所有用户:

代码语言:javascript
复制
$repository = ORM::factory( 'repository', $this->request->param('svn_name') );
$users = ORM::factory('user')->where( 'name', 'NOT IN', $repository->users->find_all()->as_array() )
            ->find_all();

不幸的是,如果没有用户连接到特定的存储库,我会收到以下错误消息:

代码语言:javascript
复制
Database_Exception [ 1064 ]: You have an error in your SQL syntax; check the manual
 that corresponds to your MySQL server version for the right syntax to use near     
')' at line 1 [ SELECT `user`.* FROM `users` AS `user` WHERE `name` NOT IN () ]

如果不使用if,而只使用Kohana-Methods,我如何解决这个问题?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-10-26 16:44:40

问题是$repository->users->find_all()->as_array()返回一个空数组,所以您的SQL查询是无效的(NOT IN () ->无效语法)。

在应用where条件之前,需要检查数组是否为空:

代码语言:javascript
复制
$repository = ORM::factory( 'repository', $this->request->param('svn_name') );
$names = $repository->users->find_all()->as_array();
$users = ORM::factory('user');

// Check against empty names
if (!empty($names))
{
   $users->where( 'name', 'NOT IN', $names );
}

// Execute the query
$users->find_all();
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13073243

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档