Make the MongoDB docs better! We value your opinion. Share your feedback for a chance to win $100.
Click here >
Docs Menu
Docs Home
/ /

$not(クエリ述語演算子)

$not

$not では、指定された <operator-expression> に対して論理 NOT 演算を実行し、 <operator-expression> に一致しないドキュメントを選択します。これには、 field を含まないドキュメントが含まれます。

次の環境でホストされる配置には $not を使用できます。

  • MongoDB Atlas はクラウドでの MongoDB 配置のためのフルマネージド サービスです

  • MongoDB Enterprise: サブスクリプションベースの自己管理型 MongoDB バージョン

  • MongoDB Community: ソースが利用可能で、無料で使用できる自己管理型の MongoDB のバージョン

$not 演算子は次の形式をとります。

{ field: { $not: { <operator-expression> } } }

次の例クエリについて考えてみます。

db.movies.find( { runtime: { $not: { $gt: 180 } } } )

この例では、次の条件を満たす movies コレクションのすべてのドキュメントを選択します。

  • runtime フィールドの値が 180 以下であるか、または

  • runtimeフィールドが存在しない場合

{ $not: { $gt: 180 } } $lte 演算子とは異なります。{ $lte: 180 } は、runtimeフィールドが存在し、その値が 180 以下のドキュメントのみを返します。

$not 演算子を別の演算子式と使用します。等価性チェックに $not を使用するには、次を使用します。

{ runtime: { $not: { $eq: 120 } } }

上記のクエリは、次のものと同等です。

{ runtime: { $ne: 120 } }

次のクエリは演算子なしでフィールドを比較するため、無効です。

{ price: { $not: 1.99 } }

$not 演算子は配列と一緒に使用すると予期しない結果を生じさせる可能性があります。複数の偽条件に基づいてドキュメントを照合するには、$nor を使用します。

このページの例では、付属の sample_mflixサンプルデータセット のデータを使用します。このデータセットを自己管理型MongoDBデプロイにロードする 方法の詳細については、「サンプルデータセットをロードする 」を参照してください。サンプルデータベースに変更を加えた場合、このページの例を実行するには、データベースを削除して再作成する必要がある場合があります。

$not は次で NOT 論理演算をサポートします。

  • /pattern/ などの正規表現オブジェクト。

    次の例では、runtime1000 分より大きく、titleT で始まっていない映画を返します。$nottitleフィールドを含まないドキュメントにも一致するため、タイトル データが利用できない場合でもクエリは映画を返します。

    db.movies.find(
    { title: { $not: /^T/ }, runtime: { $gt: 1000 } },
    { _id: 0, title: 1, runtime: 1 }
    )
    [
    { title: 'Centennial', runtime: 1256 },
    { title: 'Baseball', runtime: 1140 }
    ]
  • $regex 演算子式。

    次の 2 つのクエリでは、runtime1000 分より大きく、titleT で始まっていない映画が返されます。最初のクエリは string を $regex に渡します。

    db.movies.find(
    { title: { $not: { $regex: "^T" } }, runtime: { $gt: 1000 } },
    { _id: 0, title: 1, runtime: 1 }
    )
    [
    { title: 'Centennial', runtime: 1256 },
    { title: 'Baseball', runtime: 1140 }
    ]

    2 番目のクエリは、正規表現リテラルを $regex に渡します。

    db.movies.find(
    { title: { $not: { $regex: /^T/ } }, runtime: { $gt: 1000 } },
    { _id: 0, title: 1, runtime: 1 }
    )
    [
    { title: 'Centennial', runtime: 1256 },
    { title: 'Baseball', runtime: 1140 }
    ]
  • ドライバー言語の正規表現オブジェクト。

    たとえば、次の PyMongo クエリは Python の re.compile() メソッドを使用して正規表現をコンパイルします。

    import re
    for noMatch in db.inventory.find( { "item": { "$not": re.compile("^p.*") } } ):
    print noMatch

戻る

$nor

項目一覧