doujia7094 2018-12-13 10:00
浏览 68
已采纳

使用新的不同值更新具有相同密钥的数据库

Lets say I have a table like this,

|id|area_id|area_values|
|1 |12     |value 1    |
|2 |12     |value 2    |
|3 |12     |value 3    |
|4 |01     |value 4    |

and I would like to update only those that have an area of 12. My new values is an array $values = ['newvalue1,'newvalue2',newvalue3'];

I have tried using array_map like this.

$ids = Area::where('area_id', 12)->pluck('id')->toArray();
array_map(function ($id) {
   array_map(function($areaValue){
     Area::find($id)->update(['area_values' => $areaValue]);
   }, $values);
}, $ids)

But the problem I encountered was it's being updated with only the first value of the new array, which is newValue1

What is the best approach on doing that?

  • 写回答

2条回答 默认 最新

  • dow98764 2018-12-13 10:11
    关注

    you can do like this :

    $values = ['newvalue1','newvalue2','newvalue3'];
    $ids = Area::where('area_id', 12)->pluck('id')->toArray();
    
    foreach($ids as $index=>$id){
          Area::where('id',$id)->update(['area_values'=>$values[$index]); 
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看