简体   繁体   English

在MongoDB中的对象内插入数组

[英]Insert Array inside an object in MongoDB

I am new at MongoDB and I want to insert to mongodb data like this but I couldn't figure out how 我是MongoDB的新手,我想将这样的数据插入到mongodb中,但我不知道如何

{
  image = "cab"
  tags = [
            [ "NNP", 0 ],
            [ "NN", 1 ]
         ]
},
{
  image = "castle"
  tags = [
            [ "NNP", 2 ],
            [ "NN", 1 ],
         ]
}

my code is 我的代码是

    BasicDBObject obj = new BasicDBObject();
    obj.put("images", ....);
    for(Tag tag:tags){
    BasicDBObject tagsObj = new BasicDBObject();
    tagsObj.put("NNP",tag.getNNP());
    tagsObj.put("NN",tag.getNN());
    obj.put("tags",tagsObj);

    }

UPDATE: using this code 更新:使用此代码

Mongo m = new Mongo();
DB db = m.getDB("test");
DBCollection coll = db.getCollection("tags");
for(Tag tag:tags){
    BasicDBList dbl = new BasicDBList();
    dbl.add(new BasicDBObject("NNP",tag.getNNP()));
    dbl.add(new BasicDBObject("NN", tag.getNNP()));
    BasicDBObject outer=new BasicDBObject("images", currentImageName).append("tags", dbl);
    coll.insert(outer);
                }

I store every image alone cause the tags might be like this for the same image 我只存储每个图像,因为同一图像的标签可能像这样

  {
      image = "cab",
      tags = [
                { "NNP", 0 },
                { "NN", 1 }
             ],
             [  {"NNP", 4 },
                { "NN", 5 } 
             ],
             [
                {"NNP", 0 },
                { "NN", 4 }
             ]

}, },

Thanks 谢谢

Basically you use BasicDBObject for key-value mappings and BasicDBList for array objects. 基本上,您将BasicDBObject用于键值映射,并将BasicDBList用于数组对象。 For the object in your question, you'd do this: 对于问题中的对象,您可以这样做:

BasicDBList dbl = new BasicDBList();
dbl.add(new BasicDBObject("NNP",0));
dbl.add(new BasicDBObject("NN", 1));
BasicDBOBject outer=new BasicDBObject("image", "cab").append("tags", dbl);

There's some convenience methods in the api to make this a bit less verbose. api中有一些便捷的方法,可以使此操作不再那么冗长。

The mapping works like this: 映射如下所示:

for:  {"A":1}  use: new BasicDBObject("A",1)
for: {"A":1, "B":2}  use: new BasicDBObject("A",1).append("B",2)
for: {"A":{"B":2}}  use: new BasicDBObject("A",new BasicDBObject("B",2))
for: {"A":["B","C"]} use:
        BasicDBList dbl = new BasicDBList();
        dbl.add("B");
        dbl.add("C");
         ->  new BasicDBObject("A",dbl);

Did you mean like this? 你是这个意思吗

    BasicDBObject obj = new BasicDBObject();
    obj.put("image", ....);
    for(Tag tag:tags){
        BasicDBObject tagsObj = new BasicDBObject();
        tagsObj.put("NNP",tag.getNNP());
        tagsObj.put("NN",tag.getNN());
        obj.put("tags",tagsObj);
    }

Here is how i use it when using mongo3.x: 这是我在使用mongo3.x时的用法:

suppose you want the result to be like this: {"data": [{"key":"v1"}, {"key":"v1"}, {"key":"v1"}] } 假设您希望结果像这样: {"data": [{"key":"v1"}, {"key":"v1"}, {"key":"v1"}] }

[step1]: use Java Map to create json object which maps to the elements inside the array; [step1]:使用Java Map创建映射到数组内元素的json对象; that is, the {} inside [] 即[]中的{}

[step1 Ans]: Map m1,m2,m3 = new HashMap(); m1.put("key", "v1"); m2.put("key", "v1"); m3.put("key", "v1"); [step1 Ans]: Map m1,m2,m3 = new HashMap(); m1.put("key", "v1"); m2.put("key", "v1"); m3.put("key", "v1"); Map m1,m2,m3 = new HashMap(); m1.put("key", "v1"); m2.put("key", "v1"); m3.put("key", "v1");

[step2]: use Java List to add all Java Map into one element. [step2]:使用Java列表将所有Java Map添加到一个元素中。

[step2 Ans]: List list = new ArrayList(); list.add(m1); list.add(m2); list.add(m3); [step2 Ans]: List list = new ArrayList(); list.add(m1); list.add(m2); list.add(m3); List list = new ArrayList(); list.add(m1); list.add(m2); list.add(m3);

[step3]: add Java list into mongo [step3]:将Java列表添加到mongo中

[step3 Ans]: Document dc = new Document("key", list); [step3回答]: Document dc = new Document("key", list);

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM