2011年11月8日火曜日

gmongoでnot inを使用して検索する

gmongoでnot inを使用して検索するには、以下のコードのように$ninを使用します。
@Grab(group='com.gmongo', module='gmongo', version='0.8')
import com.mongodb.*
import com.gmongo.*

mongo = new GMongo("localhost", 27017)
db = mongo.getDB("local")
db["office_location"].drop()
// コレクションにオブジェクトを挿入する
col = db["office_location"]
col.insert([office:"Tokyo", country:"Japan", sales:100])
col.insert([office:"Sanfrancisco", country:"United States", sales:200])
col.insert([office:"Chicago", country:"United States", sales:300])
// Chicago以外のオフィスを検索
for(obj in col.find([office:['$nin':["Chicago"]]])){
  println obj
}
println "----"
// JavaScript ExpressionでChicago以外のオフィスを検索
for(obj in col.find([$where:"!(this.office in {'Chicago':1})"])){
  println obj
}

動作環境
Groovy 1.8.0, JDK6 Update22, gmongo 0.8, MongoDB 2.0

関連情報
gmongoのウェブサイト
https://github.com/poiati/gmongo

groovyとMongoDBのまとめ

0 件のコメント:

コメントを投稿