如何更新数据表中的json指定数组?

我写了个api采集漫画,漫画章节内会有很多图片,我在数据表中有个json字段 images 是为了保存漫画内容图片数组的!大概是下面这样的!

[
    "https://www.baidu.com/1.jpg",(0)
    "https://www.baidu.com/2.jpg",(1)
    "https://www.baidu.com/3.jpg",(2)
    "https://www.baidu.com/4.jpg",(3)
    "https://www.baidu.com/5.jpg",(4)
]

但是都是对方图片地址,我想图片本地化!通常是循环数组然后挨个下载给循环赋值。最后更新一次images这个字段!
这样就出现个问题,因为一个images这里有200多张图片,下载过程中如果最后一张图片下载失败其他199张图片就白下载了!
所以我的问题是,如如何能够实现下载一个文件更新一次!也就是如何更新images这个表中的指定某个值!例如只更新(2)

[
    "https://www.baidu.com/1.jpg",(0)
    "https://www.baidu.com/2.jpg",(1)
    "https://www.learnku.com/23212334324325344546546.jpg",(2)
    "https://www.baidu.com/4.jpg",(3)
    "https://www.baidu.com/5.jpg",(4)
]

如果是json字符串的可以使用一下方法更新

{
    "id": 1,
    "name": "Monkey",
    "meta": {
        "wants_newsletter": true,
        "favorite_color": "red"
    }
}


update(['meta->wants_newsletter' => false]);
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
最佳答案

@李小明

Test::query()->where('id', 115)
            ->update(['desc' => DB::raw("json_set(`desc`, '$[2]', 'https://xxx.com')")])
3年前 评论
李小明 (楼主) 3年前
bing8u 3年前
xuxx 3年前
Hollie (作者) 3年前
xuxx 3年前
xuxx 3年前
Hollie (作者) 3年前
xuxx 3年前
xuxx 3年前
Hollie (作者) 3年前
讨论数量: 6

@李小明

Test::query()->where('id', 115)
            ->update(['desc' => DB::raw("json_set(`desc`, '$[2]', 'https://xxx.com')")])
3年前 评论
李小明 (楼主) 3年前
bing8u 3年前
xuxx 3年前
Hollie (作者) 3年前
xuxx 3年前
xuxx 3年前
Hollie (作者) 3年前
xuxx 3年前
xuxx 3年前
Hollie (作者) 3年前
德国科隆街头的大胡子

你这个不考虑性能问题的话 可以每下载成功一个就取出来改了之后立即再存进去

3年前 评论
李小明 (楼主) 3年前
sreio
通常是循环数组然后挨个下载给循环赋值。最后更新一次 images 这个字段!
这样就出现个问题,因为一个 images 这里有 200 多张图片,下载过程中如果最后一张图片下载失败其他 199 张图片就白下载了!

下载失败的时候,给个默认的图片地址不就好了么,或者使用之前的图片地址

3年前 评论
李小明 (楼主) 3年前

两百多张可以考虑分表了,使用一对多!

3年前 评论
李小明 (楼主) 3年前
德国科隆街头的大胡子
        $json = test::where('id',6)->first();

        if($json){
            $json['images'] = json_decode($json['images'],true);

            $images = $json['images'];

            foreach ($json['images'] as $k=>$v){
                $img = $this->editimg($v);//处理图片返回图片地址(处理失败返回原图片地址)
                $images[$k] = $img;
            }

            $up = test::where('id',6)->update([
                'images'=>json_encode($images)
            ]);
        }
3年前 评论
李小明 (楼主) 3年前
UPDATE test
SET `desc` = JSON_SET (
    `desc`,
    '$[2]',
    '你要修改的内容'
)
WHERE
    id = xxxx;
3年前 评论
李小明 (楼主) 3年前

@李小明

Test::query()->where('id', 115)
            ->update(['desc' => DB::raw("json_set(`desc`, '$[2]', 'https://xxx.com')")])
3年前 评论
李小明 (楼主) 3年前
bing8u 3年前
xuxx 3年前
Hollie (作者) 3年前
xuxx 3年前
xuxx 3年前
Hollie (作者) 3年前
xuxx 3年前
xuxx 3年前
Hollie (作者) 3年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!