gpt4 book ai didi

java - Mongo Java 驱动程序 3.6.1 - 如何将 json 数组结构化字符串解析为 BasicDBList

转载 作者:行者123 更新时间:2023-11-29 08:29:03 25 4
gpt4 key购买 nike

当我使用 MongoDB 2.x.x 时,我使用 (BasicDBList) JSON.parse("[]") 将字符串数据解析为文档数组。但最新的 MongoDB 驱动程序表示这已被弃用,BasicDbObject.parse("") 仅转换为 BasicDBObject

这是我之前在 2.x.x Java 驱动程序中使用的一些代码示例

BasicDbList skuList = (BasicDBList) JSON.parse(skus);

所以当我升级到 3.6.1 时,编译器说这已被弃用。并建议使用 BasicDbObject.parse()

但这只接受 JSON 对象结构化字符串 ...

{ "fruit": "apple"}

...不是 JSON 数组格式的字符串。

所以,如果我有一个像这样的字符串 [\"SKU000001\",\"SKU0000002\",\"SKU0000003\"]" 如何转换为 BasicDBList

最佳答案

JSON.parse() 能够处理 JSON 数组,它读取第一个字符,如果它认为 JSON 是一个数组,它会相应地处理它:

case '[':
value = parseArray(name);
break;

BasicDBObject.parse() 需要一个有效的 JSON 文档,因此当给定一个孤立的 JSON 数组(即不包含在 JSON 文档中的 JSON 数组)时,它将抛出异常。

BasicDBObject.parse() 可以处理这个 ...

{"a": ["SKU000001", "SKU0000002", "SKU0000003"]}

...但它不能处理这个:

["SKU000001", "SKU0000002", "SKU0000003"]

因此,在 MongoDB v3.x 驱动程序中没有直接替代使用 JSON.parse() 来解析 JSON 数组。相反,您的选择是:

  1. 通过在有效的 JSON 文档中呈现 JSON 数组来欺骗 BasicDBObject.parse(),例如:

    BasicDBObject basicDBObject = BasicDBObject.parse(String.format("{\"a\": %s}",
    "[\"SKU000001\", \"SKU0000002\", \"SKU0000003\"]"));

    BasicDBList parsed = (BasicDBList) basicDBObject.get("a");
    assertThat(parsed.size(), is(3));
    assertThat(parsed, containsInAnyOrder("SKU000001", "SKU0000002", "SKU0000003"));
  2. 使用JSON解析库读取JSON数组,然后使用反序列化结果创建BasicDBList,例如::

    List<String> values = new ObjectMapper().readValue("[\"SKU000001\", \"SKU0000002\", \"SKU0000003\"]",
    List.class);

    BasicDBList parsed = new BasicDBList();
    values.forEach(s -> parsed.add(s));
    assertThat(parsed.size(), is(3));
    assertThat(parsed, containsInAnyOrder("SKU000001", "SKU0000002", "SKU0000003"));

关于java - Mongo Java 驱动程序 3.6.1 - 如何将 json 数组结构化字符串解析为 BasicDBList,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49813112/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com