注意:我最初在一小时前问了这个问题,但直到最近才意识到我犯了一个重大的复制和粘贴错误。一个如此重要,以至于删除旧帖子并重新开始更容易。对于那个很抱歉。
在 CakePHP 框架中,更新模型后,我转储了 SQL 查询。COUNT(*)
被调用了两次,没有明显的原因。
所以我有两个模型,$Foo
和$Bar
. 为简单起见,我没有定义它们之间的任何$belongsTo
关系$hasMany
。问题只涉及 $Foo,但以防万一我也包含了 $Bar 的代码。
$data = array(
'something' => 12,
'something_else' => $this->Bar->field('id', $conditions),
);
$this->Foo->id = $this->Foo->field($data);
$this->Foo->save($data);
我$Bar.id
根据一组条件(这里不相关)获得该字段。我使用该 id 来确定$data
应该 INSERT 或 UPDATE 到$Foo
. 如果$Foo
有一个满足$data
的要求的 id 将返回该值;如果不是false将被返回。根据 CakePHP 的架构,save()
如果有有效的 id 就会更新;否则它将插入。我很确定我没有做任何不寻常的事情。
这是我在 SQL 转储中看到的内容:
SELECT `Foo`.`id` FROM `foos` AS `Foo` WHERE `something` = 12 AND `something_else` = 1 LIMIT 1
SELECT COUNT(*) AS `count` FROM `foos` AS `Foo` WHERE `Foo`.`id` = 1
SELECT COUNT(*) AS `count` FROM `foos` AS `Foo` WHERE `Foo`.`id` = 1
UPDATE `foos` SET `something` = 12, something_else` = 1 WHERE `foos`.`id` = 1'
对于我的生活,我根本无法弄清楚为什么COUNT()
需要它,更不用说为什么它被调用两次了。有人知道发生了什么吗?谢谢您的帮助。