douyan3478 2015-12-03 15:46
浏览 90
已采纳

Laravel:如何在数据透视表上设置一个属性,取消设置所有其他属性

I have a many to many relationship set up, between locations and stations. A location can have many assigned stations, but only one can be active. I have a pivot table (station_location) where i'm setting an is_active attribute using a setActive method, however i'm trying to figure out a sensible way to approach setting one to active, and all others to inactive.

I need this to be reusable as i'll have to set it in multiple places (not just from a controller). I wonder if anybody has an idea of how to achieve this?

  • 写回答

1条回答 默认 最新

  • dsnrixf6765 2015-12-03 16:06
    关注

    You can use sync method as below

    $station->locations()
    ->sync([1 => ['is_active' => true], 2 => ['is_active' => false], 3 => ['is_active' => false]]);
    

    more here

    PS: 1,2,3 etc in passed array are locations ids.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥30 关于用python写支付宝扫码付异步通知收不到的问题
  • ¥50 vue组件中无法正确接收并处理axios请求
  • ¥15 隐藏系统界面pdf的打印、下载按钮
  • ¥15 MATLAB联合adams仿真卡死如何解决(代码模型无问题)
  • ¥15 基于pso参数优化的LightGBM分类模型
  • ¥15 安装Paddleocr时报错无法解决
  • ¥15 python中transformers可以正常下载,但是没有办法使用pipeline
  • ¥50 分布式追踪trace异常问题
  • ¥15 人在外地出差,速帮一点点
  • ¥15 如何使用canvas在图片上进行如下的标注,以下代码不起作用,如何修改