【问题标题】:CakePHP hasAndBelongsToMany (HABTM) Delete Joining RecordCakePHP hasAndBelongsToMany (HABTM) 删除加入记录
【发布时间】:2010-05-15 02:53:45
【问题描述】:

我在用户和位置之间存在 HABTM 关系。两个模型都有相应的$hasAndBelongsToMany 变量集。

当我管理用户位置时,我想删除用户和位置之间的关联,而不是位置。显然这个位置可能属于其他用户。我希望以下代码仅删除提供 HABTM 关联的连接表记录,但它删除了两条记录。

$this->Weather->deleteAll(array('Weather.id' => $this->data['weather_ids'], false);

但是,我是 CakePHP 的新手,所以我确信我遗漏了一些东西。我尝试将级联设置为 false 并使用用户、用户->天气、天气->用户更改模型顺序。没有运气。

提前感谢您的帮助。

【问题讨论】:

    标签: cakephp has-and-belongs-to-many


    【解决方案1】:

    不太确定Weather 与您的模型有什么关系,所以我将使用传统名称,LocationsUser 是连接表。这应该会删除 ID 为 $id 的用户与任何位置之间的所有关联:

    $this->User->LocationsUser->deleteAll(array('LocationsUser.user_id' => $id), false);
    

    另请注意,您的代码 sn-p 中缺少右括号。

    【讨论】:

    • 是的,抱歉,模型实际上是天气位置,我可以互换使用它们。你的代码是正确的,我没有意识到我可以引用关联模型。这就是我所拥有的完整性。效果刚刚好! $this->User->UsersWeather->deleteAll(array('UsersWeather.weather_id' => $this->data['weather_ids'], 'UsersWeather.user_id' => $this->user['User']['id']))
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-04-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多