Насправді getAllIds
це найкращий спосіб зробити це. Наприклад, у моделі ресурсу колекції продуктів метод виглядає так:
public function getAllIds($limit = null, $offset = null)
{
$idsSelect = $this->_getClearSelect();
$idsSelect->columns('e.' . $this->getEntity()->getIdFieldName());
$idsSelect->limit($limit, $offset);
$idsSelect->resetJoinLeft();
return $this->getConnection()->fetchCol($idsSelect, $this->_bindParams);
}
Таким чином, все витягується з одного вибору, і ітерація не потрібна. Також в абстрактній моделі ресурсів це виглядає так:
public function getAllIds()
{
$idsSelect = clone $this->getSelect();
$idsSelect->reset(Zend_Db_Select::ORDER);
$idsSelect->reset(Zend_Db_Select::LIMIT_COUNT);
$idsSelect->reset(Zend_Db_Select::LIMIT_OFFSET);
$idsSelect->reset(Zend_Db_Select::COLUMNS);
$idsSelect->columns($this->getResource()->getIdFieldName(), 'main_table');
return $this->getConnection()->fetchCol($idsSelect);
}
Тому все, що розширюється, Mage_Core_Model_Resource_Db_Collection_Abstract
має використовувати це, якщо не вказано інше.
Метод, який ви подивилися, походить із базового класу, Varien_Data_Collection
але він перезаписаний у своїх дітей.
$this->_getClearSelect()
.