V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
HardStone
V2EX  ›  PHP

mongodb update 空 object ({}) 保存为 array ([])

  •  
  •   HardStone · 70 天前 · 1327 次点击
    这是一个创建于 70 天前的主题,其中的信息可能已经有所发展或是发生改变。

    doc1:

    {
       "a": {}
    }
    

    查询出来之后添油加醋保存为另外一个 doc, 就变成了

    doc2:

    {
        "a": []
    }
    

    请问有大佬解答一下如何处理吗...

    15 条回复    2022-04-30 14:46:21 +08:00
    rust
        1
    rust  
       70 天前
    请把你"添油加醋"的代码发出来
    HardStone
        2
    HardStone  
    OP
       70 天前
    @rust #1 不是啊, "添油加醋"只是业务需求, 没有改动到这个字段
    HardStone
        3
    HardStone  
    OP
       70 天前
    @HardStone #2 也许我就不应该添油加醋地把"添油加醋"加进去
    HardStone
        4
    HardStone  
    OP
       70 天前
    就是 {} 查询出来是 [], 然后保存的时候要如何保存为原来的 {}, 搜了一些都是答非所问
    HardStone
        5
    HardStone  
    OP
       70 天前
    lambdaq
        6
    lambdaq  
       70 天前   ❤️ 3
    看到标题,心里想,这怕不是用了 php

    点进来一看,果然,分区是 php
    chendy
        7
    chendy  
       70 天前
    1. 看下 mongo 的库有没有相关配置,不把空对象读取成空数组的(类似 json_decode(json, true)
    2. 保存之前自己做判断,如果是空数组,转换成 (object) 存回去
    HardStone
        8
    HardStone  
    OP
       70 天前
    @lambdaq #6 哈哈哈哈
    HardStone
        9
    HardStone  
    OP
       70 天前
    @chendy #7 我也想到了, 但是想想, 也许可以避免存空数组 /空对象这种容易产生歧义的, 直接存 null 就不会有这个问题 /这么多额外步骤
    fuchish112
        10
    fuchish112  
       69 天前
    暂时想到的是 new \stdClass()解决
    fkdtz
        11
    fkdtz  
       69 天前   ❤️ 1
    这让我想起那天一个帖子,吐槽 json 格式复杂,一会用 [] ,一会用 {} ,还是 PHP 简洁,全都是 [] ... 逃
    sujin190
        12
    sujin190  
       69 天前
    似乎只能 new \stdClass()了,毕竟 php 想要强行区分空数组还是空字典似乎只能这样,其实吧你要是只是 php 读写似乎这样存问题也不大,就怕你还有换个语言读写的需求那真是坑人
    abigeater
        13
    abigeater  
       69 天前
    踩过这个坑,我的选择是这个字段干脆就不传了。。。 既然没数据存起来也没啥用。
    timonwong
        14
    timonwong  
       69 天前
    @lambdaq #6 我第一反应是 lua 🙈
    limingxinleo
        15
    limingxinleo  
       67 天前
    var_dump

    json_decode(json_encode(new stdClass), true)

    你就知道为什么了
    关于   ·   帮助文档   ·   API   ·   FAQ   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   3269 人在线   最高记录 5497   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 04:37 · PVG 12:37 · LAX 21:37 · JFK 00:37
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.