gpt4 book ai didi

php - CakePHP HABTM 过滤

转载 作者:行者123 更新时间:2023-11-29 00:59:12 27 4
gpt4 key购买 nike

我有两个表 - usersservers,对于 HABTM 关系,users_servers。用户 HABTM 服务器,反之亦然。

我正在尝试为 Cake 找到一种方法来选择用户分配到的服务器。

我正在尝试像 $this->User->Server->find('all'); 这样的东西,它只返回所有服务器,不管它们是否属于用户。

$this->User->Server->find('all', array('conditions' => array('Server.user_id' => 1))) 只是给出一个未知数列 SQL 错误。

我确定我遗漏了一些明显的东西,但只需要有人为我指明正确的方向。

谢谢!

最佳答案

您的表名是正确的。有很多方法可以做到这一点:

使用 Containable 行为

在您的 AppModel 中,设置以下内容:

 var $recursive = -1;
var $actsAs = array('Containable');

然后,使用以下代码查询您的服务器:

$userWithServers = $this->User->find('all', array(
'conditions' => array('User.id' => 1),
'contain' => array('Server')
));

请注意,我们正在查询用户模型,而不是服务器模型来完成此操作。

使用绑定(bind)模型

$this->Server->bindModel(array('hasOne' => array('UsersServer')));
$this->Server->find('all', array(
'fields' => array('Server.*'),
'conditions' => array('Server.user_id' => 1)
));

我个人不建议经常使用 bindModel。最终,您的代码变得有点难以管理。您应该尽可能尝试使用 Containable 行为。代码看起来更干净、更简单。有关 bindModel 方法的更多信息,请参见 here .

HTH.

关于php - CakePHP HABTM 过滤,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4502152/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com