2010-01-05 61 views
0

好的。这个版本选择的作品:帮助选择查询在ZF

$select = $this->select(); 
    $select->setIntegrityCheck(false); 
    $select->from(array('u' => $this->_name), 
        array('u.id', 'u.username', 'u.avatar_path', 
         '(SELECT COUNT(*) FROM media WHERE user_id = u.id) media_count')); 
    $where = "u.status = 'active' AND u.avatar_path <> 'images/photo-thumb.gif' AND u.show_on_homepage = 1"; 
    $where .= " AND (u.status_message IS NOT NULL OR u.profile_theme_id IS NOT NULL)"; 
    $select->where($where); 
    return $this->fetchAll($select); 

现在我所做的就是我刚才添加七号线单一的状况(MEDIA_COUNT> 0),所以它看起来是这样的:

$select = $this->select(); 
    $select->setIntegrityCheck(false); 
    $select->from(array('u' => $this->_name), 
        array('u.id', 'u.username', 'u.avatar_path', 
         '(SELECT COUNT(*) FROM media WHERE user_id = u.id) media_count')); 
    $where = "u.status = 'active' AND u.avatar_path <> 'images/photo-thumb.gif' AND u.show_on_homepage = 1"; 
    $where .= " AND (u.status_message IS NOT NULL OR u.profile_theme_id IS NOT NULL OR media_count > 0)"; 
    $select->where($where); 
    return $this->fetchAll($select); 

这已经没有按没有工作,我得到一个错误:

SQLSTATE[42S22]: Column not found: 1054 Unknown column 'm.media_count' in 'where clause' 

当我删除它的工作条件。我也尝试过使用u.media_count而没有成功。

编辑:media_count值的作品。我已经排除了条件(media_count> 0),然后对结果集做了var_dump,并且media_count的关键字在数组中具有正确的值。

EDIT2:我简化了上面的选择(我删除了不重要的行)。

回答

2

我并不特别熟悉zend-framework,但我认为问题在于media_count不是表的实际列。试着用

(SELECT COUNT(*) FROM media WHERE user_id = u.id) > 0 
+0

由于更换

media_count > 0 

。但我认为subselect查询实际上将列添加到结果集?这很奇怪。 – 2010-01-05 21:44:19