2

R と rmongodb 内で $or を使用してクエリを作成するのに苦労しています。私がエミュレートしたいのは、cmdline mongoからのこれです:

db.people.find( { $or : [ {"person.cell": { $exists : true } }, {"person.home": { $exists : true } } ] })

person.cell が null でない、または person.home が null でないレコードを取得したいと思います。それぞれを個別にクエリできますが、rmongodb で $or を使用してバッファーを作成するとデータを取得できません。rmongodb を使用する R コードは次のようになります。

l <- list("$exists"="true")
buf <- mongo.bson.buffer.create()
mongo.bson.buffer.start.array(buf, "$or")
mongo.bson.buffer.append.list(buf, "person.cell", l)
mongo.bson.buffer.append.list(buf, "person.home", l)
mongo.bson.buffer.finish.object(buf)  
b <- mongo.bson.from.buffer(buf)
mongo.find(mongo, "work.people", b)

これは、レコードもエラーも返さず、空のセットのみを返します。前述したように、person.cell または person.home のいずれかで検索を実行して結果を取得できますが、(rmongodb で) $or を実行しようとすると結果が得られないため、person.cell または person.home のいずれかでレコードをプルします。 .

私もこれを試しました:

buf <- mongo.bson.buffer.create()
mongo.bson.buffer.start.array(buf, "$or")
mongo.bson.buffer.start.object(buf, "person.cell")
mongo.bson.buffer.append(buf, "$exists", "true")
mongo.bson.buffer.finish.object(buf)
mongo.bson.buffer.start.object(buf, "person.home")
mongo.bson.buffer.append(buf, "$exists", "true")
mongo.bson.buffer.finish.object(buf)
mongo.bson.buffer.finish.object(buf)
b <- mongo.bson.from.buffer(buf)
mongo.find(mongo, "work.people", b)

しかし、同じ空のセットの結果が得られます (「b」を表示すると同じように見えます)。私はこれにこだわっています。

4

4 に答える 4

1
bson <- mongo.bson.from.JSON('{ "$or" : [ {"person.cell": { "$exists" : true } }, {"person.home": { "$exists" : true } } ] }')
mongo.find(mongo, "work.people", bson)
于 2014-01-22T01:43:16.873 に答える
1

一連の mongo.bson.buffer-statements を構成する必要がないように、JSON または list() を rmongodb で使用できる BSON オブジェクトに変換するパッケージ ( rmongodbHelper ) を作成しました。

まず、環境をセットアップしましょう。

library(rmongodb)

# install rmongodbHelper package from GitHub

library(devtools)
devtools::install_github("joyofdata/rmongodbHelper")
library(rmongodbHelper)

# the MongoDB instance

ns <- "dbx.collx"
M <- mongo.create()
mongo.is.connected(M)
mongo.remove(M, ns, json_to_bson("{}"))

# inserting a number of dummy objects
# JSON keys currently are expected to be wrapped in double quotes!

objs <- c(
  '{"_id":-1}',
  '{"_id":-2, "person":{}}',
  '{"_id":-3, "person":{"x":0}}',
  '{"_id":1,  "person":{"cell":0}}',
  '{"_id":2,  "person":{"home":0}}',
  '{"_id":3,  "person":{"cell":0,"home":0}}'
)

for(obj in objs) {
  mongo.insert(M, ns, json_to_bson(obj))
}

それらが正常に挿入されたかどうか、MongoDB シェルで確認してみましょう。

> use dbx
switched to db dbx
> db.collx.find().pretty()
{ "_id" : -1 }
{ "_id" : -2, "person" : { } }
{ "_id" : -3, "person" : { "x" : 0 } }
{ "_id" : 1, "person" : { "cell" : 0 } }
{ "_id" : 2, "person" : { "home" : 0 } }
{ "_id" : 3, "person" : { "cell" : 0, "home" : 0 } }

それでは、クエリを使用してドキュメントを検索してみましょう。

# searching for those objects
# JSON keys currently are expected to be wrapped in double quotes!

json_qry <- 
'{
  "$or" : [ 
    {"person.cell": { "$exists" : true } }, 
    {"person.home": { "$exists" : true } } 
  ] 
}'

cur <- mongo.find(M, "dbx.collx", json_to_bson(json_qry))

while(mongo.cursor.next(cur)) {
    print(mongo.cursor.value(cur))
}

そして、これが最終的に得られるものです:

_id : 1      1.000000
person : 3   
    cell : 1     0.000000

_id : 1      2.000000
person : 3   
    home : 1     0.000000

_id : 1      3.000000
person : 3   
    cell : 1     0.000000
    home : 1     0.000000
于 2014-08-24T15:06:00.690 に答える
0

RMongo では、このクエリの方が扱いやすいことがわかりました。

mongo <- mongoDbConnect(dbName="work", host="localhost",port='27017')
result <- dbGetQuery(mongo, "people","
    { '$or': [
        {'person.cell':{'$exists':true}},
        {'person.home':{'$exists':true}}
    ]}"
)

結果は になりますdata.frame

于 2012-09-16T12:51:45.793 に答える