我无法在 java 中复制 mongo 数组的更新
I can't replicate the update of a mongo array in java
我有一个具有以下结构的数据库:
{
"_id" : ObjectId("5d54608122474f8d2927d898"),
"NOMBRE_HOST" : "Base1",
"IsContingenciaODA" : "false",
"puerto" : "1532",
"HostContigencia" : "Base2",
"BASEDATOS" : [
{
"SID" : "REPOS",
"IsContingenciaBD" : "false",
"host" : "Base3",
"puerto" : "1111"
},
{
"SID" : "PRODM2",
"IsContingenciaBD" : "false",
"host" : "nb",
"puerto" : "1111"
},
{
"SID" : "PRODM3",
"IsContingenciaBD" : "true",
"host" : "Base4",
"puerto" : "999"
}
]
}
{
"_id" : ObjectId("5d54608122474f8d2927d899"),
"NOMBRE_HOST" : "172.0.0.1",
"IsContingenciaODA" : "false",
"puerto" : "1532",
"HostContigencia" : "172.10.0.1",
"BASEDATOS" : [
{
"SID" : "Base6",
"IsContingenciaBD" : "false",
"host" : "172.7.0.1",
"puerto" : "999"
}
]
}
我需要更新嵌入文档的 IsContingenciaBD 参数。
在 mongo 中更改此值的查询如下:
db.PropertiesMQ.update({"NOMBRE_HOST" : "Base1", "BASEDATOS.SID" : "PRODM3"}, {$set: {"BASEDATOS.$.IsContingenciaBD" : "true"}})
我尝试使用以下代码在 java 中复制此查询:
MongoClient client = new MongoClient("my_ip", "my_port");
MongoDatabase mongodb = client.getDatabase("prueba");
MongoCollection<Document> collection = mongodb.getCollection("PropertiesMQ");
BasicDBObject filter = new BasicDBObject();
filter.put("NOMBRE_HOST", host);
filter.put("BASEDATOS.SID", sid);
BasicDBObject data = new BasicDBObject();
data.put("BASEDATOS.$.IsContingenciaBD", state);
BasicDBObject command = new BasicDBObject();
command.put("$set", data);
System.out.println(filter + ", " + command);
collection.updateOne(filter, data);
client.close();
执行时出现以下错误:
Exception in thread "main" java.lang.IllegalArgumentException: Invalid
BSON field name BASEDATOS.$.IsContingenciaBD
看起来你在 updateOne 方法中使用了数据。相反,它应该是命令 BasicDBObject。如下图,
MongoCollection<Document> collection = mongodb.getCollection("PropertiesMQ");
BasicDBObject filter = new BasicDBObject();
filter.put("NOMBRE_HOST", host);
filter.put("BASEDATOS.SID", sid);
BasicDBObject data = new BasicDBObject();
data.put("BASEDATOS.$.IsContingenciaBD", state);
BasicDBObject command = new BasicDBObject();
command.put("$set", data);
System.out.println(filter + ", " + command);
collection.updateOne(filter, command); //Use Command instead of data
我有一个具有以下结构的数据库:
{
"_id" : ObjectId("5d54608122474f8d2927d898"),
"NOMBRE_HOST" : "Base1",
"IsContingenciaODA" : "false",
"puerto" : "1532",
"HostContigencia" : "Base2",
"BASEDATOS" : [
{
"SID" : "REPOS",
"IsContingenciaBD" : "false",
"host" : "Base3",
"puerto" : "1111"
},
{
"SID" : "PRODM2",
"IsContingenciaBD" : "false",
"host" : "nb",
"puerto" : "1111"
},
{
"SID" : "PRODM3",
"IsContingenciaBD" : "true",
"host" : "Base4",
"puerto" : "999"
}
]
}
{
"_id" : ObjectId("5d54608122474f8d2927d899"),
"NOMBRE_HOST" : "172.0.0.1",
"IsContingenciaODA" : "false",
"puerto" : "1532",
"HostContigencia" : "172.10.0.1",
"BASEDATOS" : [
{
"SID" : "Base6",
"IsContingenciaBD" : "false",
"host" : "172.7.0.1",
"puerto" : "999"
}
]
}
我需要更新嵌入文档的 IsContingenciaBD 参数。 在 mongo 中更改此值的查询如下:
db.PropertiesMQ.update({"NOMBRE_HOST" : "Base1", "BASEDATOS.SID" : "PRODM3"}, {$set: {"BASEDATOS.$.IsContingenciaBD" : "true"}})
我尝试使用以下代码在 java 中复制此查询:
MongoClient client = new MongoClient("my_ip", "my_port");
MongoDatabase mongodb = client.getDatabase("prueba");
MongoCollection<Document> collection = mongodb.getCollection("PropertiesMQ");
BasicDBObject filter = new BasicDBObject();
filter.put("NOMBRE_HOST", host);
filter.put("BASEDATOS.SID", sid);
BasicDBObject data = new BasicDBObject();
data.put("BASEDATOS.$.IsContingenciaBD", state);
BasicDBObject command = new BasicDBObject();
command.put("$set", data);
System.out.println(filter + ", " + command);
collection.updateOne(filter, data);
client.close();
执行时出现以下错误:
Exception in thread "main" java.lang.IllegalArgumentException: Invalid BSON field name BASEDATOS.$.IsContingenciaBD
看起来你在 updateOne 方法中使用了数据。相反,它应该是命令 BasicDBObject。如下图,
MongoCollection<Document> collection = mongodb.getCollection("PropertiesMQ");
BasicDBObject filter = new BasicDBObject();
filter.put("NOMBRE_HOST", host);
filter.put("BASEDATOS.SID", sid);
BasicDBObject data = new BasicDBObject();
data.put("BASEDATOS.$.IsContingenciaBD", state);
BasicDBObject command = new BasicDBObject();
command.put("$set", data);
System.out.println(filter + ", " + command);
collection.updateOne(filter, command); //Use Command instead of data