0

我在使用 idiORM 类时遇到了问题。(在此处找到的文档:http: //idiorm.readthedocs.org/en/latest/

我试图获取某个查询的计数,同时保留原始查询以供进一步处理,所以我只是将原始查询复制到第二个变量中,但似乎只要我执行该count()方法,他就会将所有内容复制到另一个变量.

例如,我创建一个查询并将返回的 ORM 对象保存到一个变量中$ormResults 并将其复制到$copy

$ormResults = ORM::for_table('department')->where('company', '4');
$this->_orginalResults = $ormResults;

// Copy the ORM object into $copy
$copy = $ormResults;
$this->resultCount = $copy->count();

直到这里它工作正常,预期的计数结果正确存储在$this->resultCount. 但是,当我现在 var 转储(到目前为止)未使用的变量$this->_orginalResults时,它还包含使我感到困惑的count()属性,因为我根本没有使用它。

protected '_resultColumns' => 
array
  0 => string 'COUNT(*) AS `count`' (length=19)

当我尝试执行$this->_originalResults->findMany();. 这是因为该count()方法返回的是 ORM 对象吗?据我所知,PHP 代码不会向上传播.. 是吗?

所以Tl;博士:

$test = ORM::forTable('departments')->where('company', '8');
$test2 = $test;
// Works
var_dump($test->count());

// Fails
var_dump($test2->findMany());

然而,这工作得很好:

$test = ORM::forTable('departments')->where('company', '8');
$test2 = ORM::forTable('departments')->where('company', '8');

var_dump($test->count());
var_dump($test2->findMany());

任何见解/帮助将不胜感激。

4

1 回答 1

2

好的,明白了,显然一些静态变量正在破坏它。

使用clone复制对象完美。

$test = ORM::forTable('departments')->where('company', '8');
$test2 = clone $test;

 var_dump($test->count());
 var_dump($test2->findMany());

有诀窍吗

于 2013-06-02T14:10:21.157 回答