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条)

报告相同问题?

悬赏问题

  • ¥100 c语言,请帮蒟蒻看一个题
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)